



# REALTEK

## RTL9607C SINGLE-CHIP PON

Realtek confidential for tenda

### L2 Table Application Note

(CONFIDENTIAL: Development Partners Only)

Rev. 1.0.0  
2 June 2017



Realtek Semiconductor Corp.

No. 2, Innovation Road II, Hsinchu Science Park, Hsinchu 300, Taiwan

Tel.: +886-3-578-0211 Fax: +886-3-577-6047

[www.realtek.com](http://www.realtek.com)





## COPYRIGHT

©2017 Realtek Semiconductor Corp. All rights reserved. No part of this document may be reproduced, transmitted, transcribed, stored in a retrieval system, or translated into any language in any form or by any means without the written permission of Realtek Semiconductor Corp.

## TRADEMARKS

Realtek is a trademark of Realtek Semiconductor Corporation. Other names mentioned in this document are trademarks/registered trademarks of their respective owners.

## **DISCLAIMER**

Realtek provides this document "as is", without warranty of any kind, neither expressed nor implied, including, but not limited to, the particular purpose. Realtek may make improvements and/or changes in this document or in the product described in this document at any time. This document could include technical inaccuracies or typographical errors.

## **USING THIS DOCUMENT**

Though every effort has been made to assure that this document is current and accurate, more information may have become available subsequent to the production of this guide. In that event, please contact your Realtek representative for additional information that may help in the development process.

## **CONFIDENTIALITY**

This document is confidential and should not be provided to a third-party without the permission of Realtek Semiconductor Corporation.

## REVISION HISTORY

| Revision | Release Date | Summary       |
|----------|--------------|---------------|
| 1.0.0    | 2017/06/02   | First Release |



## Table of Contents

|      |                                            |             |
|------|--------------------------------------------|-------------|
| 1.   | OVERVIEW .....                             | 1           |
| 2.   | L2 TABLE LEARNING .....                    | 3           |
| 2.1. | INDEPENDENT & SHARED VLAN LEARNING .....   | 3           |
| 3.   | L2 TABLE LOOKUP & FORWARDING.....          | 6           |
| 3.1. | INDEPENDENT & SHARED VLAN FORWARDING ..... | 6           |
| 3.2. | IPv4 MULTICAST LOOKUP .....                | 7           |
| 3.3. | IPv6 MULTICAST LOOKUP .....                | 10          |
| 3.4. | UNKNOWN PACKET CONTROL.....                | 11          |
| 3.5. | SOURCE PORT FILTERING .....                | 12          |
| 4.   | L2 TABLE CONFIGURATION .....               | 13          |
| 4.1. | AGEING TIMER.....                          | 13          |
| 4.2. | LEARNING LIMITATION .....                  | 13          |
| 4.3. | LINK DOWN FLUSH .....                      | 14          |
| 5.   | L2 TABLE ENTRY OPERATION .....             | 16          |
| 5.1. | BLOCK .....                                | 16          |
| 5.2. | AUTHENTICATION .....                       | 錯誤! 尚未定義書籤。 |
| 5.3. | L3 MULTICAST ROUTING .....                 | 錯誤! 尚未定義書籤。 |
| 6.   | SAMPLE CODE .....                          | 17          |
| 6.1. | INITIALIZATION .....                       | 17          |
| 6.2. | ADD & DELETE AN ENTRY .....                | 17          |
| 6.3. | GET AN EXIST ENTRY .....                   | 20          |
| 6.4. | DUMP ENTIRE L2 TABLE .....                 | 22          |
| 6.5. | LEARNING LIMITATION & ACTION .....         | 24          |
| 6.6. | AGEING TIMER.....                          | 25          |
| 6.7. | FLUSH CONTROL.....                         | 25          |
| 6.8. | SOURCE PORT FILTERING .....                | 25          |

## List of Tables

|                                              |    |
|----------------------------------------------|----|
| TABLE 1. L2 TABLE FIELD .....                | 2  |
| TABLE 2. LEARNING ACTION SETTING.....        | 5  |
| TABLE 3. IGMP_SIP_FILTER_TBL.....            | 9  |
| TABLE 4. UNKNOWN MULTICAST CONTROL.....      | 11 |
| TABLE 5. SOURCE PORT FILTERING CONTROL ..... | 12 |
| TABLE 6. AGEING TIMER CONTROL.....           | 13 |
| TABLE 7. LEARNING LIMITATION CONTROL .....   | 13 |
| TABLE 8. LEARNING LIMITATION CONTROL .....   | 14 |

## List of Figures

|                                            |   |
|--------------------------------------------|---|
| FIGURE 1. L2 TABLE ENTRY FORMAT .....      | 1 |
| FIGURE 2. L2 TABLE ENTRY DECODE FLOW ..... | 2 |
| FIGURE 3. L2 TABLE LEARNING FLOW .....     | 3 |
| FIGURE 4. LOOKUP DECISION FLOW.....        | 6 |

Realtek confidential for tenda

## 1. Overview

L2 table in RTL9607C is a 2K entries table. This table is operated by a 4 way hash mechanism. Each entry in L2 table is 80 bits long and can be either L2 or L3 entry. The following figure gives all 3 types of L2 table entry.



**Figure 1.** L2 Table entry format

Type 0 is L2 unicast type which can be created by users or dynamic learning by RTL9607C.

Type 1 is used to support L2 multicast. This type should be always static entry and only be created / deleted by software.

Type 2 is IPv4 multicast type. This type should be always static entry and only be created / deleted by software.

RTL9607C uses the following mechanism to determinate the type of entry. After knowing the type of entry, RTL9607C can extract each field in entry for further usage.



**Figure 2. L2 Table entry decode flow**

By knowing type of L2 entry, RTL9607C can extract the following fields from entry. All fields in L2 Table entry is listed as following.

**Table 1.** L2 Table Field

| Field      | Description                                                                                                                                 | Bits |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------|------|
| MAC        | MAC address                                                                                                                                 | 48   |
| FID        | FID                                                                                                                                         | 2    |
| L3LOOKUP   | L3 or L2 lookup                                                                                                                             | 1    |
| MBR        | Port list                                                                                                                                   | 11   |
| EXT_MBRIDX | Index for Extension port list of EXT 17-0                                                                                                   | 5    |
| NOTSALEARN | Not ASIC SA auto learning entry<br>1. unicast entry is valid if NOTSALREAN=1 or AGE!=0<br>2. L2/L3 multicast entry is valid if NOTSALREAN=1 | 1    |
| SABLOCK    | Source MAC blocking                                                                                                                         | 1    |
| DABLOCK    | Destination MAC blocking                                                                                                                    | 1    |
| AGE        | Aging Time                                                                                                                                  | 3    |
| SPA        | Source port of learning address                                                                                                             | 4    |
| EXT_SPA    | Source extension of learning address                                                                                                        | 3    |
| L2CVID     | Learning Ctag VID(SVL and Ctagging) or Ingress CVLAN VID(IVL or untagging)                                                                  | 12   |
| IVL_SVL    | L2 hash with VID(IVL_SVL=1) or FID(IVL_SVL=0)                                                                                               | 1    |
| ARP_USAGE  | Unicast address for ARP usage                                                                                                               | 1    |
| CTAG_IF    | C-tagging or not for ingress CVLAN learning                                                                                                 | 1    |

## 2. L2 Table Learning

When RTL9607C receives a packet, it will try to lookup the source MAC address of packet in L2 table. If this is a new MAC address, RTL9607C will try to write this MAC into L2 Table. If this is MAC address already exists in L2 Table, RTL9607C will update its port number information and refresh ageing timer field in this entry.

RTL9607C supports IVL (independent VLAN Learning), SVL (Shared VLAN Learning) and Hybrid (Both IVL & SVL) mode. The IVL and SVL mode selection in learning is dependent on VLAN setting. Thus, users can configure some VLANs in IVL and others in SVL. If a VLAN is configured in IVL mode, all the packets belonging to this VLAN will be learned in IVL mode and vice versa. The entire learning procedure in IVL and SAL is given in the following section.

All the dynamic entries learned by RTL9607C are always type 0 which is defined in Figure 1.

### 2.1. Independent & Shared VLAN Learning



Figure 3. L2 Table learning flow



When the learning process begins, RTL9607C will try to get the learning mode of this packet from VLAN table. This is because that RTL9607C needs to calculate the hash key before trying to locate an index in L2 Table. If learning mode is SVL, RTL9607C will use MAC + FID to calculate hash key. If learning mode is IVL, RTL9607C will use MAC + VID to calculate hash key. The hash key calculation algorithm for L2 unicast entry is given as following.

#### L2 Unicast (SVL):

$$\begin{aligned} \text{key [08]} &= \text{MAC}_{08} \oplus \text{MAC}_{17} \oplus \text{MAC}_{26} \oplus \text{MAC}_{35} \oplus \text{MAC}_{44} \\ \text{key [07]} &= \text{MAC}_{07} \oplus \text{MAC}_{16} \oplus \text{MAC}_{25} \oplus \text{MAC}_{34} \oplus \text{MAC}_{43} \\ \text{key [06]} &= \text{MAC}_{06} \oplus \text{MAC}_{15} \oplus \text{MAC}_{24} \oplus \text{MAC}_{33} \oplus \text{MAC}_{42} \\ \text{key [05]} &= \text{MAC}_{05} \oplus \text{MAC}_{14} \oplus \text{MAC}_{23} \oplus \text{MAC}_{32} \oplus \text{MAC}_{41} \\ \text{key [04]} &= \text{MAC}_{04} \oplus \text{MAC}_{13} \oplus \text{MAC}_{22} \oplus \text{MAC}_{31} \oplus \text{MAC}_{40} \oplus \text{FID}_{01} \\ \text{key [03]} &= \text{MAC}_{03} \oplus \text{MAC}_{12} \oplus \text{MAC}_{21} \oplus \text{MAC}_{30} \oplus \text{MAC}_{39} \oplus \text{FID}_{00} \\ \text{key [02]} &= \text{MAC}_{02} \oplus \text{MAC}_{11} \oplus \text{MAC}_{20} \oplus \text{MAC}_{29} \oplus \text{MAC}_{38} \oplus \text{MAC}_{47} \\ \text{key [01]} &= \text{MAC}_{01} \oplus \text{MAC}_{10} \oplus \text{MAC}_{19} \oplus \text{MAC}_{28} \oplus \text{MAC}_{37} \oplus \text{MAC}_{46} \\ \text{key [00]} &= \text{MAC}_{00} \oplus \text{MAC}_{09} \oplus \text{MAC}_{18} \oplus \text{MAC}_{27} \oplus \text{MAC}_{36} \oplus \text{MAC}_{45} \end{aligned}$$

#### L2 Unicast (IVL):

$$\begin{aligned} \text{key [08]} &= \text{MAC}_{08} \oplus \text{MAC}_{17} \oplus \text{MAC}_{26} \oplus \text{MAC}_{35} \oplus \text{MAC}_{44} \oplus \text{VID}_{05} \\ \text{key [07]} &= \text{MAC}_{07} \oplus \text{MAC}_{16} \oplus \text{MAC}_{25} \oplus \text{MAC}_{34} \oplus \text{MAC}_{43} \oplus \text{VID}_{04} \\ \text{key [06]} &= \text{MAC}_{06} \oplus \text{MAC}_{15} \oplus \text{MAC}_{24} \oplus \text{MAC}_{33} \oplus \text{MAC}_{42} \oplus \text{VID}_{03} \\ \text{key [05]} &= \text{MAC}_{05} \oplus \text{MAC}_{14} \oplus \text{MAC}_{23} \oplus \text{MAC}_{32} \oplus \text{MAC}_{41} \oplus \text{VID}_{02} \oplus \text{VID}_{11} \\ \text{key [04]} &= \text{MAC}_{04} \oplus \text{MAC}_{13} \oplus \text{MAC}_{22} \oplus \text{MAC}_{31} \oplus \text{MAC}_{40} \oplus \text{VID}_{01} \oplus \text{VID}_{10} \\ \text{key [03]} &= \text{MAC}_{03} \oplus \text{MAC}_{12} \oplus \text{MAC}_{21} \oplus \text{MAC}_{30} \oplus \text{MAC}_{39} \oplus \text{VID}_{00} \oplus \text{VID}_{09} \\ \text{key [02]} &= \text{MAC}_{02} \oplus \text{MAC}_{11} \oplus \text{MAC}_{20} \oplus \text{MAC}_{29} \oplus \text{MAC}_{38} \oplus \text{MAC}_{47} \oplus \text{VID}_{08} \\ \text{key [01]} &= \text{MAC}_{01} \oplus \text{MAC}_{10} \oplus \text{MAC}_{19} \oplus \text{MAC}_{28} \oplus \text{MAC}_{37} \oplus \text{MAC}_{46} \oplus \text{VID}_{07} \\ \text{key [00]} &= \text{MAC}_{00} \oplus \text{MAC}_{09} \oplus \text{MAC}_{18} \oplus \text{MAC}_{27} \oplus \text{MAC}_{36} \oplus \text{MAC}_{45} \oplus \text{VID}_{06} \end{aligned}$$

No matter which learning mode is, RTL9607C will get a 9 bits hash key (0~511) after the calculation. Every 4 indexes in L2 Tables share the same hash key. In other words, RTL9607C only needs to lookup 4 entries and it can know a specified entry is in L2 Table or not.

By having the hash key, RTL9607C would look up the specified MAC in these 4 entries. If the MAC address is found, RTL9607C will compare the source port information between L2 entry and packet received port number. If the source port number is matched, it will refresh the ageing time field in L2 entry. If the source port number is not matched, the action is controlled by LUT\_UNMATCHED\_SA\_CTRL. Only when the action of LUT\_UNMATCHED\_SA\_CTRL is setting



## RTL9600 L2 Table Application Note

as “Normal”, RTL9607C would update the source port number in L2 entry and refresh the Ageing timer field. All other settings will not change the exist entry in L2 Table.

If the MAC address is not found in L2 Table, this action is controlled by LUT\_UNKN\_SA\_CTRL. Just like LUT\_UNMATCHED\_SA\_CTRL, when the action of LUT\_UNKN\_SA\_CTRL is setting as “Normal”, RTL9607C would update the source port number in L2 entry and refresh the Ageing timer field. Otherwise, the original entry will not be touched.

All 4 actions of LUT\_UNMATCHED\_SA\_CTRL & LUT\_UNKN\_SA\_CTRL are listed:

**Table 2. Learning action setting**

| Field Name            | Bits | Description                                                                                                                                                                                                                                   |
|-----------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LUT_UNKN_SA_CTRL      | 2    | Per-port drop/trap packet if SA is unknown<br>0b00: normal<br>0b01: drop packet & disable learning<br>0b10: trap to CPU & disable learning<br>0b11: reserved                                                                                  |
| LUT_UNMATCHED_SA_CTRL | 2    | Per-port drop/trap packet if SA is not from the same source port as L2 SPA. If SPA is CPU port, then need to check EXT_SPA.<br>0b00: normal<br>0b01: drop packet & disable learning<br>0b10: trap to CPU & disable learning<br>0b11: reserved |

### 3. L2 Table Lookup & Forwarding

When RTL9607C needs to forward a packet out, it will do a lookup in L2 table and forward the packet to the port/port mask in L2 entry. RTL9607C supports L2 unicast, L2 multicast & L3 multicast forwarding. That is, RTL9607C needs to know to calculate the hash key before lookup. The following figure shows the decision of hash key calculation.



Figure 4. Lookup decision flow

#### 3.1. Independent & Shared VLAN Forwarding

If the decision of lookup is Type 0, RTL9607C will use MAC + VID/FID to calculate the hash key. Like dynamic address learning, RTL9607C needs to know IVL or SVL before calculate. By having this information, RTL9607C can calculate a hash key and lookup into L2 Table. The hash key calculation algorithm for Type 0 is as same as dynamic address learning in section 2.1. For Type 0, the hash key calculation algorithm is as following:

L2 Multicast (SVL):

key [08] = MAC<sub>08</sub>⊕MAC<sub>17</sub>⊕MAC<sub>26</sub>⊕MAC<sub>35</sub>⊕MAC<sub>44</sub>  
 key [07] = MAC<sub>07</sub>⊕MAC<sub>16</sub>⊕MAC<sub>25</sub>⊕MAC<sub>34</sub>⊕MAC<sub>43</sub>  
 key [06] = MAC<sub>06</sub>⊕MAC<sub>15</sub>⊕MAC<sub>24</sub>⊕MAC<sub>33</sub>⊕MAC<sub>42</sub>  
 key [05] = MAC<sub>05</sub>⊕MAC<sub>14</sub>⊕MAC<sub>23</sub>⊕MAC<sub>32</sub>⊕MAC<sub>41</sub>  
 key [04] = MAC<sub>04</sub>⊕MAC<sub>13</sub>⊕MAC<sub>22</sub>⊕MAC<sub>31</sub>⊕MAC<sub>40</sub>⊕FID<sub>01</sub>  
 key [03] = MAC<sub>03</sub>⊕MAC<sub>12</sub>⊕MAC<sub>21</sub>⊕MAC<sub>30</sub>⊕MAC<sub>39</sub>⊕FID<sub>00</sub>  
 key [02] = MAC<sub>02</sub>⊕MAC<sub>11</sub>⊕MAC<sub>20</sub>⊕MAC<sub>29</sub>⊕MAC<sub>38</sub>⊕MAC<sub>47</sub>  
 key [01] = MAC<sub>01</sub>⊕MAC<sub>10</sub>⊕MAC<sub>19</sub>⊕MAC<sub>28</sub>⊕MAC<sub>37</sub>⊕MAC<sub>46</sub>  
 key [00] = MAC<sub>00</sub>⊕MAC<sub>09</sub>⊕MAC<sub>18</sub>⊕MAC<sub>27</sub>⊕MAC<sub>36</sub>⊕MAC<sub>45</sub>

### L2 Multicast (IVL):

key [08] = MAC<sub>08</sub>⊕MAC<sub>17</sub>⊕MAC<sub>26</sub>⊕MAC<sub>35</sub>⊕MAC<sub>44</sub>⊕VID<sub>05</sub>  
key [07] = MAC<sub>07</sub>⊕MAC<sub>16</sub>⊕MAC<sub>25</sub>⊕MAC<sub>34</sub>⊕MAC<sub>43</sub>⊕VID<sub>04</sub>  
key [06] = MAC<sub>06</sub>⊕MAC<sub>15</sub>⊕MAC<sub>24</sub>⊕MAC<sub>33</sub>⊕MAC<sub>42</sub>⊕VID<sub>03</sub>  
key [05] = MAC<sub>05</sub>⊕MAC<sub>14</sub>⊕MAC<sub>23</sub>⊕MAC<sub>32</sub>⊕MAC<sub>41</sub>⊕VID<sub>02</sub>⊕VID<sub>11</sub>  
key [04] = MAC<sub>04</sub>⊕MAC<sub>13</sub>⊕MAC<sub>22</sub>⊕MAC<sub>31</sub>⊕MAC<sub>40</sub>⊕VID<sub>01</sub>⊕VID<sub>10</sub>  
key [03] = MAC<sub>03</sub>⊕MAC<sub>12</sub>⊕MAC<sub>21</sub>⊕MAC<sub>30</sub>⊕MAC<sub>39</sub>⊕VID<sub>00</sub>⊕VID<sub>09</sub>  
key [02] = MAC<sub>02</sub>⊕MAC<sub>11</sub>⊕MAC<sub>20</sub>⊕MAC<sub>29</sub>⊕MAC<sub>38</sub>⊕MAC<sub>47</sub>⊕VID<sub>08</sub>  
key [01] = MAC<sub>01</sub>⊕MAC<sub>10</sub>⊕MAC<sub>19</sub>⊕MAC<sub>28</sub>⊕MAC<sub>37</sub>⊕MAC<sub>46</sub>⊕VID<sub>07</sub>  
key [00] = MAC<sub>00</sub>⊕MAC<sub>09</sub>⊕MAC<sub>18</sub>⊕MAC<sub>27</sub>⊕MAC<sub>36</sub>⊕MAC<sub>45</sub>⊕VID<sub>06</sub>

If the entry is found in L2 Table, the packet will be forwarded to port / port mask according to the SPA or MBR/EXT\_MBR field of the entry. If the entry is not found, this packet will follow unknown packet control action. We will discuss this at Section 3.4.

### **3.2. IPv4 Multicast Lookup**

If the decision of lookup is Type 3 to 7 that means this packet is an IPv4 multicast packet. RTL9607C will do the IPv4 multicast lookup and forwarding. RTL9607C will use GIP + SIP + VID/FID to calculate the hash key. The hash key calculation is as following:

IPv4 Multicast while LUT\_IPMC\_VLAN\_MODE=2 && LUT\_IPMC\_HASH=1 (Type3):

key [08] = GIP<sub>08</sub>⊕GIP<sub>17</sub>⊕GIP<sub>26</sub>⊕VID<sub>05</sub>  
 key [07] = GIP<sub>07</sub>⊕GIP<sub>16</sub>⊕GIP<sub>25</sub>⊕VID<sub>04</sub>  
 key [06] = GIP<sub>06</sub>⊕GIP<sub>15</sub>⊕GIP<sub>24</sub>⊕VID<sub>03</sub>  
 key [05] = GIP<sub>05</sub>⊕GIP<sub>14</sub>⊕GIP<sub>23</sub>⊕VID<sub>02</sub>⊕VID<sub>11</sub>  
 key [04] = GIP<sub>04</sub>⊕GIP<sub>13</sub>⊕GIP<sub>22</sub>⊕VID<sub>01</sub>⊕VID<sub>10</sub>



key [03] = GIP<sub>03</sub>⊕GIP<sub>12</sub>⊕GIP<sub>21</sub>⊕VID<sub>00</sub>⊕VID<sub>09</sub>

key [02] = GIP<sub>02</sub>⊕GIP<sub>11</sub>⊕GIP<sub>20</sub> ⊕VID<sub>08</sub>

key [01] = GIP<sub>01</sub>⊕GIP<sub>10</sub>⊕GIP<sub>19</sub> ⊕VID<sub>07</sub>

key [00] = GIP<sub>00</sub>⊕GIP<sub>09</sub>⊕GIP<sub>18</sub>⊕GIP<sub>27</sub>⊕VID<sub>06</sub>

IPv4 Multicast while LUT\_IPMC\_VLAN\_MODE=2 && LUT\_IPMC\_HASH=1 (Type4):

key [08] = GIP<sub>08</sub>⊕GIP<sub>17</sub>⊕GIP<sub>26</sub>

key [07] = GIP<sub>07</sub>⊕GIP<sub>16</sub>⊕GIP<sub>25</sub>

key [06] = GIP<sub>06</sub>⊕GIP<sub>15</sub>⊕GIP<sub>24</sub>

key [05] = GIP<sub>05</sub>⊕GIP<sub>14</sub>⊕GIP<sub>23</sub>

key [04] = GIP<sub>04</sub>⊕GIP<sub>13</sub>⊕GIP<sub>22</sub>

key [03] = GIP<sub>03</sub>⊕GIP<sub>12</sub>⊕GIP<sub>21</sub>

key [02] = GIP<sub>02</sub>⊕GIP<sub>11</sub>⊕GIP<sub>20</sub>

key [01] = GIP<sub>01</sub>⊕GIP<sub>10</sub>⊕GIP<sub>19</sub>

key [00] = GIP<sub>00</sub>⊕GIP<sub>09</sub>⊕GIP<sub>18</sub>⊕GIP<sub>27</sub>

IPv4 Multicast while LUT\_IPMC\_VLAN\_MODE=0 && LUT\_IPMC\_HASH=1 (Type5):

key [08] = GIP<sub>08</sub>⊕GIP<sub>17</sub>⊕GIP<sub>26</sub>

key [07] = GIP<sub>07</sub>⊕GIP<sub>16</sub>⊕GIP<sub>25</sub>

key [06] = GIP<sub>06</sub>⊕GIP<sub>15</sub>⊕GIP<sub>24</sub>

key [05] = GIP<sub>05</sub>⊕GIP<sub>14</sub>⊕GIP<sub>23</sub>

key [04] = GIP<sub>04</sub>⊕GIP<sub>13</sub>⊕GIP<sub>22</sub>⊕FID<sub>01</sub>

key [03] = GIP<sub>03</sub>⊕GIP<sub>12</sub>⊕GIP<sub>21</sub>⊕FID<sub>00</sub>

key [02] = GIP<sub>02</sub>⊕GIP<sub>11</sub>⊕GIP<sub>20</sub>

key [01] = GIP<sub>01</sub>⊕GIP<sub>10</sub>⊕GIP<sub>19</sub>

key [00] = GIP<sub>00</sub>⊕GIP<sub>09</sub>⊕GIP<sub>18</sub>⊕GIP<sub>27</sub>

IPv4 Multicast while LUT\_IPMC\_VLAN\_MODE=2 && LUT\_IPMC\_HASH=2 && Hit IGMP\_MC\_GROUP (Type6):

key [08] = GIP<sub>08</sub>⊕GIP<sub>17</sub>⊕GIP<sub>26</sub>⊕SIP<sub>07</sub>⊕SIP<sub>16</sub>⊕SIP<sub>25</sub>

key [07] = GIP<sub>07</sub>⊕GIP<sub>16</sub>⊕GIP<sub>25</sub>⊕SIP<sub>06</sub>⊕SIP<sub>15</sub>⊕SIP<sub>24</sub>

key [06] = GIP<sub>06</sub>⊕GIP<sub>15</sub>⊕GIP<sub>24</sub>⊕SIP<sub>05</sub>⊕SIP<sub>14</sub>⊕SIP<sub>23</sub>

key [05] = GIP<sub>05</sub>⊕GIP<sub>14</sub>⊕GIP<sub>23</sub>⊕SIP<sub>04</sub>⊕SIP<sub>13</sub>⊕SIP<sub>22</sub>⊕SIP<sub>31</sub>

key [04] = GIP<sub>04</sub>⊕GIP<sub>13</sub>⊕GIP<sub>22</sub>⊕SIP<sub>03</sub>⊕SIP<sub>12</sub>⊕SIP<sub>21</sub>⊕SIP<sub>30</sub>

key [03] = GIP<sub>03</sub>⊕GIP<sub>12</sub>⊕GIP<sub>21</sub>⊕SIP<sub>02</sub>⊕SIP<sub>11</sub>⊕SIP<sub>20</sub>⊕SIP<sub>29</sub>

key [02] = GIP<sub>02</sub>⊕GIP<sub>11</sub>⊕GIP<sub>20</sub>⊕SIP<sub>01</sub>⊕SIP<sub>10</sub>⊕SIP<sub>19</sub>⊕SIP<sub>28</sub>

key [01] = GIP<sub>01</sub>⊕GIP<sub>10</sub>⊕GIP<sub>19</sub>⊕SIP<sub>00</sub>⊕SIP<sub>09</sub>⊕SIP<sub>18</sub>⊕SIP<sub>27</sub>

key [00] = GIP<sub>00</sub>⊕GIP<sub>09</sub>⊕GIP<sub>18</sub>⊕GIP<sub>27</sub>⊕SIP<sub>08</sub>⊕SIP<sub>16</sub>⊕SIP<sub>26</sub>



IPv4 Multicast while LUT\_IPMC\_VLAN\_MODE=2 && LUT\_IPMC\_HASH=2 && NO Hit IGMP\_MC\_GROUP (Type7):

```

key [08] = GIP08⊕GIP17⊕GIP26
key [07] = GIP07⊕GIP16⊕GIP25
key [06] = GIP06⊕GIP15⊕GIP24
key [05] = GIP05⊕GIP14⊕GIP23
key [04] = GIP04⊕GIP13⊕GIP22
key [03] = GIP03⊕GIP12⊕GIP21
key [02] = GIP02⊕GIP11⊕GIP20
key [01] = GIP01⊕GIP10⊕GIP19
key [00] = GIP00⊕GIP09⊕GIP18⊕GIP27

```

If the entry is not found, this packet will follow unknown packet control action. We will discuss this at Section 3.4

For supporting include/exclude mode forwarding which is defined in IGMPv3. RTL9607C uses L2 Table and IGMP\_MC\_GROUP to offer this functionality. IGMP\_MC\_GROUP is a 64 entries table and given as following:

**Table 3. IGMP\_SIP\_FILTER\_TBL**

| Field      | Description                               | Bits |
|------------|-------------------------------------------|------|
| Valid      | Valid entry                               | 1    |
| GIPn       | IP Multicast Group Address                | 28   |
| MBR        | Port list                                 | 11   |
| EXT_MBRIDX | Index for Extension port list of EXT 17-0 | 5    |

GIP is multicast group IP. The multicast IP address is always class D address. When RTL9607C try to forward an IPv4 multicast packet and LUT\_IPMC\_HASH is 2, ASIC will lookup IGMP\_MC\_GROUP first. If the GIP hit an entry in IGMP\_MC\_GROUP, then ASIC will hash by GIP+SIP. If the result of lookup IGMP\_MC\_GROUP table is miss, ASIC will only use GIP to look entry up in L2 table. After L2 table hash, ASIC will forward the packet according to the MBR in IGMP\_MC\_GROUP or L2 Table.

If users need an IGMPv3 Include mode group setting, users should create an entry in IGMP\_MC\_GROUP and add an associated {GIP, SIP, MBR != 0} entry in L2 Table. Thus, ASIC will refer the L2 table MBR as forward port mask.

If users need an Exclude mode group setting, users should set the SIP entry as {GIP, SIP, MBR=0} in L2 Table, and create an associated IGMP\_MC\_GROUP entry with correct MBR or EXT\_MBRIDX. That is, if the packet could not hit any entry in L2 table but it get hit in IGMP\_MC\_GROUP, ASIC would forward it to MBR or EXT\_MBRIDX in IPMC\_GROUP\_TABLE.

### 3.3. IPv6 Multicast Lookup

In RTL9607C, the IPv6 multicast packet might be classified to Type0 to Type3. RTL9607C will do the L2 table hash only by MAC+FID/VID. The hash key calculation is as following:

Type0 SVL:

$$\begin{aligned} \text{key [08]} &= \text{MAC}_{08} \oplus \text{MAC}_{17} \oplus \text{MAC}_{26} \oplus \text{MAC}_{35} \oplus \text{MAC}_{44} \\ \text{key [07]} &= \text{MAC}_{07} \oplus \text{MAC}_{16} \oplus \text{MAC}_{25} \oplus \text{MAC}_{34} \oplus \text{MAC}_{43} \\ \text{key [06]} &= \text{MAC}_{06} \oplus \text{MAC}_{15} \oplus \text{MAC}_{24} \oplus \text{MAC}_{33} \oplus \text{MAC}_{42} \\ \text{key [05]} &= \text{MAC}_{05} \oplus \text{MAC}_{14} \oplus \text{MAC}_{23} \oplus \text{MAC}_{32} \oplus \text{MAC}_{41} \\ \text{key [04]} &= \text{MAC}_{04} \oplus \text{MAC}_{13} \oplus \text{MAC}_{22} \oplus \text{MAC}_{31} \oplus \text{MAC}_{40} \oplus \text{FID}_{01} \\ \text{key [03]} &= \text{MAC}_{03} \oplus \text{MAC}_{12} \oplus \text{MAC}_{21} \oplus \text{MAC}_{30} \oplus \text{MAC}_{39} \oplus \text{FID}_{00} \\ \text{key [02]} &= \text{MAC}_{02} \oplus \text{MAC}_{11} \oplus \text{MAC}_{20} \oplus \text{MAC}_{29} \oplus \text{MAC}_{38} \oplus \text{MAC}_{47} \\ \text{key [01]} &= \text{MAC}_{01} \oplus \text{MAC}_{10} \oplus \text{MAC}_{19} \oplus \text{MAC}_{28} \oplus \text{MAC}_{37} \oplus \text{MAC}_{46} \\ \text{key [00]} &= \text{MAC}_{00} \oplus \text{MAC}_{09} \oplus \text{MAC}_{18} \oplus \text{MAC}_{27} \oplus \text{MAC}_{36} \oplus \text{MAC}_{45} \end{aligned}$$

Type0 IVL:

$$\begin{aligned} \text{key [08]} &= \text{MAC}_{08} \oplus \text{MAC}_{17} \oplus \text{MAC}_{26} \oplus \text{MAC}_{35} \oplus \text{MAC}_{44} \oplus \text{VID}_{05} \\ \text{key [07]} &= \text{MAC}_{07} \oplus \text{MAC}_{16} \oplus \text{MAC}_{25} \oplus \text{MAC}_{34} \oplus \text{MAC}_{43} \oplus \text{VID}_{04} \\ \text{key [06]} &= \text{MAC}_{06} \oplus \text{MAC}_{15} \oplus \text{MAC}_{24} \oplus \text{MAC}_{33} \oplus \text{MAC}_{42} \oplus \text{VID}_{03} \\ \text{key [05]} &= \text{MAC}_{05} \oplus \text{MAC}_{14} \oplus \text{MAC}_{23} \oplus \text{MAC}_{32} \oplus \text{MAC}_{41} \oplus \text{VID}_{02} \oplus \text{VID}_{11} \\ \text{key [04]} &= \text{MAC}_{04} \oplus \text{MAC}_{13} \oplus \text{MAC}_{22} \oplus \text{MAC}_{31} \oplus \text{MAC}_{40} \oplus \text{VID}_{01} \oplus \text{VID}_{10} \\ \text{key [03]} &= \text{MAC}_{03} \oplus \text{MAC}_{12} \oplus \text{MAC}_{21} \oplus \text{MAC}_{30} \oplus \text{MAC}_{39} \oplus \text{VID}_{00} \oplus \text{VID}_{09} \\ \text{key [02]} &= \text{MAC}_{02} \oplus \text{MAC}_{11} \oplus \text{MAC}_{20} \oplus \text{MAC}_{29} \oplus \text{MAC}_{38} \oplus \text{MAC}_{47} \oplus \text{VID}_{08} \\ \text{key [01]} &= \text{MAC}_{01} \oplus \text{MAC}_{10} \oplus \text{MAC}_{19} \oplus \text{MAC}_{28} \oplus \text{MAC}_{37} \oplus \text{MAC}_{46} \oplus \text{VID}_{07} \\ \text{key [00]} &= \text{MAC}_{00} \oplus \text{MAC}_{09} \oplus \text{MAC}_{18} \oplus \text{MAC}_{27} \oplus \text{MAC}_{36} \oplus \text{MAC}_{45} \oplus \text{VID}_{06} \end{aligned}$$

Type1:

$$\begin{aligned} \text{key [08]} &= \text{MAC}_{08} \oplus \text{MAC}_{17} \oplus \text{MAC}_{26} \oplus \text{MAC}_{35} \oplus \text{MAC}_{44} \oplus \text{VID}_{05} \\ \text{key [07]} &= \text{MAC}_{07} \oplus \text{MAC}_{16} \oplus \text{MAC}_{25} \oplus \text{MAC}_{34} \oplus \text{MAC}_{43} \oplus \text{VID}_{04} \\ \text{key [06]} &= \text{MAC}_{06} \oplus \text{MAC}_{15} \oplus \text{MAC}_{24} \oplus \text{MAC}_{33} \oplus \text{MAC}_{42} \oplus \text{VID}_{03} \\ \text{key [05]} &= \text{MAC}_{05} \oplus \text{MAC}_{14} \oplus \text{MAC}_{23} \oplus \text{MAC}_{32} \oplus \text{MAC}_{41} \oplus \text{VID}_{02} \oplus \text{VID}_{11} \\ \text{key [04]} &= \text{MAC}_{04} \oplus \text{MAC}_{13} \oplus \text{MAC}_{22} \oplus \text{MAC}_{31} \oplus \text{MAC}_{40} \oplus \text{VID}_{01} \oplus \text{VID}_{10} \\ \text{key [03]} &= \text{MAC}_{03} \oplus \text{MAC}_{12} \oplus \text{MAC}_{21} \oplus \text{MAC}_{30} \oplus \text{MAC}_{39} \oplus \text{VID}_{00} \oplus \text{VID}_{09} \\ \text{key [02]} &= \text{MAC}_{02} \oplus \text{MAC}_{11} \oplus \text{MAC}_{20} \oplus \text{MAC}_{29} \oplus \text{MAC}_{38} \oplus \text{MAC}_{47} \oplus \text{VID}_{08} \\ \text{key [01]} &= \text{MAC}_{01} \oplus \text{MAC}_{10} \oplus \text{MAC}_{19} \oplus \text{MAC}_{28} \oplus \text{MAC}_{37} \oplus \text{MAC}_{46} \oplus \text{VID}_{07} \\ \text{key [00]} &= \text{MAC}_{00} \oplus \text{MAC}_{09} \oplus \text{MAC}_{18} \oplus \text{MAC}_{27} \oplus \text{MAC}_{36} \oplus \text{MAC}_{45} \oplus \text{VID}_{06} \end{aligned}$$

Type2:

```

key [08] = MAC08⊕MAC17⊕MAC26⊕MAC35⊕MAC44
key [07] = MAC07⊕MAC16⊕MAC25⊕MAC34⊕MAC43
key [06] = MAC06⊕MAC15⊕MAC24⊕MAC33⊕MAC42
key [05] = MAC05⊕MAC14⊕MAC23⊕MAC32⊕MAC41
key [04] = MAC04⊕MAC13⊕MAC22⊕MAC31⊕MAC40
key [03] = MAC03⊕MAC12⊕MAC21⊕MAC30⊕MAC39
key [02] = MAC02⊕MAC11⊕MAC20⊕MAC29⊕MAC38⊕MAC47
key [01] = MAC01⊕MAC10⊕MAC19⊕MAC28⊕MAC37⊕MAC46
key [00] = MAC00⊕MAC09⊕MAC18⊕MAC27⊕MAC36⊕MAC45

```

If the entry is not found, this packet will follow unknown packet control action. We will discuss this at Section 3.4.

### 3.4. Unknown Packet Control

If the decision of lookup for a packet is Type 0, that also means the packet is an L2 unicast packet. If its destination MAC address can not be founded in L2 Table, it will be classified as an “Unknown unicast” packet. This kind of packet is controlled by LUT<sub>UNKN\_UC\_DA\_CTRL</sub>. The possible action of this control can be Flooding / Drop / Trap to CPU. If Users configure this action as “Flooding”, users can also specify the “Flooding port mask for unknown unicast”.

If the decision of lookup for a packet is not Type 0, this packet is a multicast packet. (Either L2 or L3) If its destination MAC or GIP address can not be founded in L2 Table, it will be classified as an “Unknown Multicast” packet. 3 registers control the behavior of this kind of packet dependent on packet format.

**Table 4. Unknown Multicast Control**

| Field Name        | Bits | Description                                                                                                                                                                                                                                                                                                                                                          |
|-------------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| UNKN_IP4_MC_ACT   | 2    | Per port unknown IPv4 multicast frame behaviour<br>0b00: normal flooding, exclude IGMP packets<br>0b01: drop packet, exclude IP 224.0.0.x only when UNKN_RESERVED_IP4_ACT != 0 and IGMP packets<br>0b10: trap to CPU, exclude IP 224.0.0.x only when UNKN_RESERVED_IP4_ACT != 0 and IGMP packets<br>0b11: Reserved                                                   |
| UNKN_IP6_MC_ACT_L | 2    | Per port unknown Ipv6 multicast frame behaviour<br>0b00: normal flooding, exclude MLD packets<br>0b01: drop packet, exclude UNKN_MC_IP6_RSV_ADDR configured addressonly when UNKN_RESERVED_IP6_ACT != 0 and MLD packets<br>0b10: trap to CPU, exclude UNKN_MC_IP6_RSV_ADDR configured address only when UNKN_RESERVED_IP6_ACT != 0 and MLD packets<br>0b11: Reserved |
| UNKN_L2_MC_ACT    | 2    | Per port unknown L2 multicast frame behaviour<br>0b00: normal flooding exclude IGMP/MLD                                                                                                                                                                                                                                                                              |



---

0b01: drop packet exclude IGMP/MLD  
0b10: trap to CPU exclude IGMP/MLD  
0b11: drop packet exclude RMA(01-80-C2-00-00-xx)/IGMP/MLD

---

If users configure above configuration as “Flooding”, users can also configure it flooding port mask.

### 3.5. Source Port Filtering

No matter the packet type and the lookup result (known or unknown), the packet will not be forwarded to the port which RTL9607C receive it. Even if the source port is set in the MBR/EXT\_MBR, RTL9607C will mask out this port when egress. However, some application may need RTL9607C forward the packet back, the following configuration give the ability to permit/forbid this kind of forwarding behavior.

Table 5. Source Port Filtering Control

| Field Name         | Bits | Description                                                                                                                                                            |
|--------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| L2_SRC_PORT_PERMIT | 1    | Per-port don't filter packet if source port and destination port are the same<br>0b0: normal, filtering source port in forwarding portmask<br>0b1: just forward packet |
| L2_SRC_EXT_PERMIT  | 1    | Per-EXT don't filter packet if source port and destination port are the same<br>0b0: normal, filtering source port in forwarding portmask<br>0b1: just forward packet  |

#### **4. L2 Table Configuration**

This section gives some features discussion of L2 Table. RTL9607C supports automatically dynamic learning for L2 unicast address. An Ageing timer mechanism is also provided to collect entry space from unused entry. Ageing timer is configurable and will be discussed at section 4.1.

Another feature of learning limitation, users can specify a per-port or per-system learning limitation. Learning over action for those packets which can not be learned due to this limitation can be configured also. This feature is discussed at Section 4.2.

Once a port is link down, users can request to clear all dynamic entries. This configuration is give at Section 4.3.

#### **4.1. Ageing Timer**

RTL9607C provides the following configuration to control the ageing mechanism.

**Table 6. Ageing Timer Control**

| <b>Field Name</b> | <b>Bits</b> | <b>Description</b>                                                                      |
|-------------------|-------------|-----------------------------------------------------------------------------------------|
| LUT_AGEOUT_CTRL   | 1           | Per-port L2 LUT age update setting<br>0b0: disable age update<br>0b1: enable age update |
| AGE_SPD           | 21          | L2 lookup table aging speed/period for each 2K entries, unit 0.1 sec<br>0b0:reserved    |

By default, LUT\_AGEOUT\_CTRL is 0x1. That means the ageing mechanism is enabled. AGE\_SPEED is used for controlling the time period which a dynamic L2 entry can exist in L2 Table. When a dynamic L2 entry is learned or refreshed, the Age field in L2 entry will be set to 7. This field will be decreased by Aging mechanism. If this field is decreased to 0, the L2 entry is deleted.

The time period of decreasing Age field from 7 to 0 is AGE SPEED.

#### **4.2. Learning Limitation**

The size of L2 Table in RTL9607C is 2K entries. However, RTL9607C also provides the following control register to configure a system-based and port-based limitation.

**Table 7. Learning Limitation Control**

| <b>Field Name</b>  | <b>Bits</b> | <b>Description</b>                               |
|--------------------|-------------|--------------------------------------------------|
| LUT_LRN_LIMITNO    | 12          | System and per-port L2 entries limitation number |
| LUT_LEARN_OVER_ACT | 2           | Per-port auto leaning number exceed behavior     |

|                      |    |                                                                                                                                                           |
|----------------------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
|                      |    | 0b00: normal forwarding<br>0b01: drop packet<br>0b10: trap to CPU<br>0b11: Reserved(as 0b00)                                                              |
| LUT_SYS_LRNLIMITNO   | 12 | System-based L2 entries limitation number                                                                                                                 |
| LUT_SYS_LRNOVER_CTRL | 2  | System-based auto leaning number exceed behavior<br>0b00: normal forwarding<br>0b01: drop packet<br>0b10: trap to CPU<br>0b11: Reserved(as 0b00)          |
| LUT_SYS_LRNLIMIT_EN  | 1  | Per port learning count is counted as system-based L2 learning count and need to check system-based learning limit<br>0b0: disable<br>0b1: enable         |
| LUT_ENTRY_FULL_ACT   | 1  | SMAC(unicast only) can not be learned because LUT 4 way entries full (without CAM) or LUT 4 way + CAM full (with CAM)<br>0b0: Forward<br>0b1: Trap to CPU |

Per-port leaning counters and system learning counter are used to count the number of dynamic entries. Before a new dynamic entry is learned, the learning counters will be compared to LUT\_LRNLIMITNO. A dynamic address can be learned only when the port-based and system-based limitation is not reached. User can set not using system learning counter by LUT\_SYS\_LRNLIMIT\_EN.

Only dynamic L2 entry will be counted in learning counters. Static entries will not affect the behavior of learning limitation function.

If dynamic entry learned by ASIC can't find empty entry, we can decide this entry to forward or trap to CPU.

### 4.3. Link down Flush

If a port of RTL9607C is link down, RTL9607C will flush all the dynamic entries in that port by default. The following configuration can be used to control this behavior.

**Table 8. Learning Limitation Control**

| Field Name        | Bits | Description                                                                                                                             |
|-------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------|
| LUT_FLUSH_DYNAMIC | 1    | Flush dynamic entries(both ARP_USAGE=0 and NOTSALEARN=0)<br>0b1: enable                                                                 |
| LUT_FLUSH_STATIC  | 1    | Flush static entries(include ARP_USAGE=1 or NOTSALEARN=1)<br>0b1: enable                                                                |
| LINKDOWN_AGEOUT   | 1    | Link down port aging out setting<br>0b0:disable aging out<br>0b1:enable force aging out all L2 lookup entries belong to link down ports |

If LINKDOWN\_AGEOUT is set to 1, RTL9607C will flush entries when port is link down. The type of entries which will be flushed is controlled by LUT\_FLUSH\_DYNAMIC and LUT\_FLUSH\_STATIC.

&lt;

/ 31 &gt;

④ ⑤

视图

△ 标记

批注

Q



**RTL9600  
L2 Table Application Note**

Realtek confidential for tenda

0



## 5. L2 Table Entry operation

Some fields in L2 entry are used to perform additional feature. The following section would discuss these fields and their functionality.

### 5.1. Block

The easiest way to configure RTL9607C dropping a packet with specified destination MAC address or a source MAC address is to use DA\_BLOCK and SA\_BLOCK field in a L2 entry. When RTL9607C receives a packet, it will do a source MAC address lookup in L2 Table for learning. If L2 entry is found and SA\_BLOCK of the L2 entry is set, this packet will be dropped.

Like SA\_BLOCK, when RTL9607C do the destination MAC address lookup and L2 entry with DA\_BLOCK setting exists, this packet will be dropped.

**SA\_BLOCK** function works on all types of packets due to RTL9607C will perform source MAC lookup for every incoming packet. However, if the lookup decision is not L2 unicast, there is no **DA\_BLOCK** action will be performed due to this field is only in Type 0.

## 6. Sample code

This chapter gives some sample code to configure the functionality of L2 Table via SDK.

### 6.1. Initialization

API “rtk\_l2\_init” can be used to initialize entire L2 module. This API can also be used as reset function. When this function is called, L2 module will be reset.

```
/* Initialize L2 Module */  
rtk_l2_init();
```

## **6.2. Add & Delete an entry**

All 4 types of L2 entry can be added and deleted by SDK. This section gives the sample for adding and deleting a L2 entry in L2 Table.

```
/* Add an IVL L2 unicast entry with MAC: 00:01:02:03:04:05 and VID = 1 */
/* source port = 2, source address priority = 4 */

rtk_l2_unicastAddr_t l2Addr;

osal_memset(&l2Addr, 0x00, sizeof(rtk_l2_unicastAddr_t));
l2Addr.vid = 1;
L2Addr.mac.octet[0] = 0x00;
L2Addr.mac.octet[1] = 0x01;
L2Addr.mac.octet[2] = 0x02;
L2Addr.mac.octet[3] = 0x03;
L2Addr.mac.octet[4] = 0x04;
L2Addr.mac.octet[5] = 0x05;
L2Addr.port = 2;
L2Addr.priority = 4;
L2Addr.flags = (RTK_L2_UCAST_FLAG_LOOKUP_PRI |
                RTK_L2_UCAST_FLAG_STATIC |
                RTK_L2_UCAST_FLAG_IVL );
```

```
rtk_l2_addr_add(&l2Addr);
```

```
/* Delete an IVL L2 unicast entry with MAC: 00:01:02:03:04:05, VID = 1 */

rtk_l2_unicastAddr_t l2Addr;

osal_memset(&l2Addr, 0x00, sizeof(rtk_l2_unicastAddr_t));
l2Addr.vid = 1;
L2Addr.mac.octet[0] = 0x00;
L2Addr.mac.octet[1] = 0x01;
L2Addr.mac.octet[2] = 0x02;
L2Addr.mac.octet[3] = 0x03;
L2Addr.mac.octet[4] = 0x04;
L2Addr.mac.octet[5] = 0x05;
L2Addr.flags = (RTK_L2_UCAST_FLAG_STATIC |
                  RTK_L2_UCAST_FLAG_IVL );

rtk_l2_addr_del(&l2Addr);
```

```
/* Add an SVL L2 multicast entry with MAC: 01:80:C2:11:22:33, FID = 3 */
/* port mask = UTP port 0~3 */

rtk_l2_mcastAddr_t l2Mcast;

osal_memset(&l2Mcast, 0x00, sizeof(rtk_l2_mcastAddr_t));
l2Mcast.fid = 3;
l2Mcast.mac.octet[0] = 0x01;
l2Mcast.mac.octet[1] = 0x80;
l2Mcast.mac.octet[2] = 0xC2;
l2Mcast.mac.octet[3] = 0x11;
l2Mcast.mac.octet[4] = 0x22;
l2Mcast.mac.octet[5] = 0x33;
RTK_PORTMASK_RESET(&ipmcAddr.portmask);
```



```
RTK_PORTMASK_PORT_SET(&ipmcAddr.portmask, RTK_PORT_UTP0);
RTK_PORTMASK_OR (&ipmcAddr.portmask, RTK_PORT_UTP1);
RTK_PORTMASK_OR (&ipmcAddr.portmask, RTK_PORT_UTP2);
RTK_PORTMASK_OR (&ipmcAddr.portmask, RTK_PORT_UTP3);

rtk_l2_mcastAddr_add(&l2Mcast);
```

```
/* Delete an SVL L2 multicast entry with MAC: 01:80:C2:11:22:33, FID = 3 */
tk_l2_mcastAddr_t l2Mcast;

osal_memset(&l2Mcast, 0x00, sizeof(rtk_l2_mcastAddr_t));
l2Mcast.fid = 3;
l2Mcast.mac.octet[0] = 0x01;
l2Mcast.mac.octet[1] = 0x80;
l2Mcast.mac.octet[2] = 0xC2;
l2Mcast.mac.octet[3] = 0x11;
l2Mcast.mac.octet[4] = 0x22;
l2Mcast.mac.octet[5] = 0x33;

rtk_l2_mcastAddr_del(&l2Mcast);
```

```
/* Add an IP multicast entry with DIP = 224.1.2.3, SIP = 10.1.1.1 */
/* port mask = UTP port 0~3 */

rtk_l2_ipMcastAddr_t ipmcAddr;

osal_memset(&ipmcAddr, 0x00, sizeof(rtk_l2_ipMcastAddr_t));
ipmcAddr.dip = 0xE0010203;
ipmcAddr.sip = 0x0A010101;
ipmcAddr.flags |= RTK_L2_IPMCAST_FLAG_STATIC;
```



```
RTK_PORTMASK_RESET(&ipmcAddr.portmask);
RTK_PORTMASK_PORT_SET(&ipmcAddr.portmask, RTK_PORT_UTP0);
RTK_PORTMASK_OR (&ipmcAddr.portmask, RTK_PORT_UTP1);
RTK_PORTMASK_OR (&ipmcAddr.portmask, RTK_PORT_UTP2);
RTK_PORTMASK_OR (&ipmcAddr.portmask, RTK_PORT_UTP3);

rtk_12_ipMcastAddr_add(&l2Mcast);
```

```
/* Delete an IP multicast entry with DIP = 224.1.2.3, SIP = 10.1.1.1 */

rtk_l2_ipMcastAddr_t ipmcAddr;

osal_memset(&ipmcAddr, 0x00, sizeof(rtk_l2_ipMcastAddr_t));
ipmcAddr.dip = 0xE0010203;
ipmcAddr.sip = 0xA010101;
ipmcAddr.flags |= RTK_L2_IPMCICAST_FLAG_STATIC;

rtk_l2_ipMcastAddr_del(&l2Mcast);
```

### **6.3. Get an Exist Entry**

Like Addition and deletion, RTL9607C SDK also provides API to get an exist entry in L2 Table.

```
/* Get an IVL L2 unicast entry with MAC: 00:01:02:03:04:05, VID = 1 */

int32 ret;
rtk_l2_unicastAddr_t l2Addr;

osal_memset(&l2Addr, 0x00, sizeof(rtk_l2_unicastAddr_t));
l2Addr.vid = 1;
L2Addr.mac.octet[0] = 0x00;
L2Addr.mac.octet[1] = 0x01;
L2Addr.mac.octet[2] = 0x02;
L2Addr.mac.octet[3] = 0x03;
```



```
L2Addr.mac.octet[4] = 0x04;  
L2Addr.mac.octet[5] = 0x05;  
L2Addr.flags = (RTK_L2_UCAST_FLAG_STATIC |  
                 RTK_L2_UCAST_FLAG_IVL );  
  
ret = rtk_l2_addr_get(&l2Addr);  
if(ret == RT_ERR_OK)  
    /* Entry found */  
else  
    /* Entry not found */
```

```
/* Get an SVL L2 multicast entry with MAC: 01:80:C2:11:02:33, FID = 3 */  
  
int32 ret;  
tk_l2_mcastAddr_t l2Mcast;  
  
osal_memset(&l2Mcast, 0x00, sizeof(rtk_l2_mcastAddr_t));  
l2Mcast.fid = 3;  
l2Mcast.mac.octet[0] = 0x01;  
l2Mcast.mac.octet[1] = 0x80;  
l2Mcast.mac.octet[2] = 0xC2;  
l2Mcast.mac.octet[3] = 0x11;  
l2Mcast.mac.octet[4] = 0x02;  
l2Mcast.mac.octet[5] = 0x33;  
  
ret = rtk_l2_mcastAddr_get(&l2Mcast);  
if(ret == RT_ERR_OK)  
    /* Entry found */  
else  
    /* Entry not found */
```

```
/* Get an IP multicast entry with DIP = 224.1.2.3, SIP = 10.1.1.1 */  
  
int32 ret;
```

```
rtk_12_ipMcastAddr_t ipmcAddr;

osal_memset(&ipmcAddr, 0x00, sizeof(rtk_12_ipMcastAddr_t));
ipmcAddr.dip = 0xE0010203;
ipmcAddr.sip = 0x0A010101;
ipmcAddr.flags |= RTK_L2_IPMCICAST_FLAG_STATIC;

ret = rtk_12_ipMcastAddr_get(&l2Mcast);
if(ret == RT_ERR_OK)
    /* Entry found */
else
    /* Entry not found */
```

#### **6.4. Dump entire L2 Table**

Section 6.3 gives the sample code for getting a specified entry. However, if users don't know the MAC/IP address of a L2 entry or they just want dump entire L2 table, the following sample can be used to do this.

Each entry in L2 table will be assigned an “address,” which is from 0 to 2047. This address represents the physical position of an entry in L2 table. When user use API to dump L2 table, RTL9607C SDK API will request users to input an address and the API will return the next valid entry in L2 Table and its physical address. Users can use this returned address as next address input until the address returned by SDK API is smaller than input.

```
/* Dump L2 unicast entry */

int32 ret;
int32 address = 0;
int32 pre_addr;
rtk_l2_unicastAddr_t l2Addr;

osal_memset(&l2Addr, 0x00, sizeof(rtk_l2_unicastAddr_t));

do
{
    pre_addr = address;
    ret = rtk_l2_nextValidAddr_get(&address, &l2Addr), ret)
```



```
if(ret != RT_ERR_OK)
    break;

if(address < pre_addr)
    break;
}while(1)
```

```
/* Dump L2 multicast entry */

int32 ret;
int32 address = 0;
int32 pre_addr;
rtk_l2_mcastAddr_t l2Mcast;

osal_memset(&l2Mcast, 0x00, sizeof(rtk_l2_mcastAddr_t));

do
{
    pre_addr = address;
    ret = rtk_l2_nextValidMcastAddr_get(&address, &l2Mcast), ret);
    if(ret != RT_ERR_OK)
        break;

    if(address < pre_addr)
        break;
}while(1)
```

```
/* Dump L3 multicast entry */

int32 ret;
int32 address = 0;
int32 pre_addr;
rtk_l2_ipMcastAddr_t ipmcAddr;
```

```
osal_memset(&ipmcAddr, 0x00, sizeof(rtk_l2_ipMcastAddr_t));  
  
do  
{  
    pre_addr = address;  
    ret = rtk_l2_nextValidIpMcastAddr_get(&address, &ipmcAddr), ret);  
    if(ret != RT_ERR_OK)  
        break;  
  
    if(address < pre_addr)  
        break;  
}while(1)
```

## 6.5. Learning Limitation & Action

RTL9607C provides port-based and system-based learning limitation. Learning over action can be configurable for both kinds of limitations.

```
/* Set port 2 learning limitation to 20 entries */  
/* Set port 2 learning over action as drop */  
  
rtk_l2_portLimitLearningCnt_set(2, 20);  
rtk_l2_portLimitLearningCntAction_set(2, LIMIT_LEARN_CNT_ACTION_DROP);
```

```
/* Set system learning limitation to 1000 entries */  
/* Set system learning over action as forward */  
  
rtk_l2_limitLearningCnt_set(1000);  
rtk_l2_limitLearningCntAction_set(LIMIT_LEARN_CNT_ACTION_FORWARD);
```

## 6.6. Ageing Timer

The ageing timer is the time period that a used dynamic entry can exist in L2 Table. When a dynamic L2 entry doesn't be referenced in ageing timer period, it may be deleted by RTL9607C.

The ageing timer configuration sample code is as following

```
/* Set Ageing timer to 300 seconds */

rtk_l2_aging_set(300);
```

## 6.7. Flush Control

RTL9607C SDK can flush dynamic & static entry in L2 Table

```
/* Flush all dynamic entry at UTP port 0 */
rtk_l2_flushCfg_t cfg;
uint32 phyPortNum;

rtk_switch_phyPortId_get(RTK_PORT_UTP0, &phyPortNum);

cfg.flushByPort = 1;
cfg.port = phyPortNum;
cfg.flushDynamicAddr = 1;
cfg.flushStaticAddr = 0;
rtk_l2_ucastAddr_flush(&cfg);
```

## 6.8. Source Port Filtering

By default, RTL9607C will not forward packet to the port which it receives this packet. This function is called "source port filtering". RTL9607C SDK API provides API to enable/disable this function.



## RTL9600 L2 Table Application Note

```
/* Disable UTP Port 2 & 3 source port filtering */

rtk_portmask_t portmask ;

RTK_PORTMASK_RESET(portmask);
RTK_PORTMASK_PORT_SET (&portmask, RTK_PORT_UTP2);
RTK_PORTMASK_PORT_SET (&portmask, RTK_PORT_UTP3);
rtk_l2_srcPortEgrFilterMask_set(&portmask);
```

Realtek confidential for tenda



RTL9600  
L2 Table Application Note

Hsinchu 300, Taiwan, R.O.C.

Tel: 886-3-5780211 Fax: 886-3-5776047

[www.realtek.com](http://www.realtek.com)

Realtek confidential for tenda

全文阅读已结束，下载本文需要使用



下载此文档

阅读了该文档的用户还阅读了这些文档



RTL9607C\_L2\_Table

发表评论

验证码： 换一张

匿名评论

提交

## 关于我们

关于道客巴巴

[网站声明](#)

人才招聘

[网站地图](#)

联系我们

[APP下载](#)

## 帮助中心

[会员注册](#)

[文档下载](#)

[如何获取积分](#)

## 关注我们

[新浪微博](#)

道客巴巴网站 版权所有 | ©2008-2025 | 网站备案：京ICP备18056798号-1 京公网安备11010802036365号

