net: dsa: mv88e6xxx: fix handling of upper half of STATS_TYPE_PORT
authorRasmus Villemoes <rasmus.villemoes@prevas.dk>
Wed, 29 May 2019 07:02:11 +0000 (07:02 +0000)
committerDavid S. Miller <davem@davemloft.net>
Thu, 30 May 2019 19:28:06 +0000 (12:28 -0700)
Currently, the upper half of a 4-byte STATS_TYPE_PORT statistic ends
up in bits 47:32 of the return value, instead of bits 31:16 as they
should.

Fixes: 6e46e2d821bb ("net: dsa: mv88e6xxx: Fix u64 statistics")
Signed-off-by: Rasmus Villemoes <rasmus.villemoes@prevas.dk>
Reviewed-by: Vivien Didelot <vivien.didelot@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/dsa/mv88e6xxx/chip.c

index 28414db979b0594aa266783e08e7db4036174e1a..12f165a71a6c7b6c91c60e64e51799cdbcc90345 100644 (file)
@@ -785,7 +785,7 @@ static uint64_t _mv88e6xxx_get_ethtool_stat(struct mv88e6xxx_chip *chip,
                        err = mv88e6xxx_port_read(chip, port, s->reg + 1, &reg);
                        if (err)
                                return U64_MAX;
-                       high = reg;
+                       low |= ((u32)reg) << 16;
                }
                break;
        case STATS_TYPE_BANK1: