realtek: fix RTL839x egress tag for ports >= 32
authorJan Hoffmann <jan@3e8.eu>
Sun, 25 Sep 2022 12:32:31 +0000 (14:32 +0200)
committerSander Vanheule <sander@svanheule.net>
Sun, 25 Sep 2022 18:53:24 +0000 (20:53 +0200)
Don't overwrite AS_DPM and L2LEARNING flags when dest_port is >= 32.

Fixes: 1773264a0c6d ("realtek: correct egress frame port verification")
Signed-off-by: Jan Hoffmann <jan@3e8.eu>
target/linux/realtek/files-5.10/drivers/net/ethernet/rtl838x_eth.c

index e96c5a7216f8344cb047087f931fcc06f92ab02e..d497b4cc8caa5dcbd6ad6f6dae2df4492ab98d55 100644 (file)
@@ -116,7 +116,7 @@ static void rtl839x_create_tx_header(struct p_hdr *h, unsigned int dest_port, in
        // h->cpu_tag[1] |= BIT(1) | BIT(0); // Bypass filter 1/2
        if (dest_port >= 32) {
                dest_port -= 32;
-               h->cpu_tag[2] = BIT(dest_port) >> 16;
+               h->cpu_tag[2] |= (BIT(dest_port) >> 16) & 0xf;
                h->cpu_tag[3] = BIT(dest_port) & 0xffff;
        } else {
                h->cpu_tag[4] = BIT(dest_port) >> 16;