mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-16 15:36:45 +07:00
c3a7d4ade5
The ATU Learn2All feature allows newly learnt addresses to be spanned on ports marked as "Message Port", currently all DSA ports. This commit enables this feature which is necessary and quite convenient for multi-chip switch fabrics. Signed-off-by: Vivien Didelot <vivien.didelot@savoirfairelinux.com> Signed-off-by: David S. Miller <davem@davemloft.net>
46 lines
1.9 KiB
C
46 lines
1.9 KiB
C
/*
|
|
* Marvell 88E6xxx Switch Global (1) Registers support
|
|
*
|
|
* Copyright (c) 2008 Marvell Semiconductor
|
|
*
|
|
* Copyright (c) 2016 Vivien Didelot <vivien.didelot@savoirfairelinux.com>
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
* (at your option) any later version.
|
|
*/
|
|
|
|
#ifndef _MV88E6XXX_GLOBAL1_H
|
|
#define _MV88E6XXX_GLOBAL1_H
|
|
|
|
#include "mv88e6xxx.h"
|
|
|
|
int mv88e6xxx_g1_read(struct mv88e6xxx_chip *chip, int reg, u16 *val);
|
|
int mv88e6xxx_g1_write(struct mv88e6xxx_chip *chip, int reg, u16 val);
|
|
int mv88e6xxx_g1_wait(struct mv88e6xxx_chip *chip, int reg, u16 mask);
|
|
|
|
int mv88e6185_g1_reset(struct mv88e6xxx_chip *chip);
|
|
int mv88e6352_g1_reset(struct mv88e6xxx_chip *chip);
|
|
|
|
int mv88e6185_g1_ppu_enable(struct mv88e6xxx_chip *chip);
|
|
int mv88e6185_g1_ppu_disable(struct mv88e6xxx_chip *chip);
|
|
|
|
int mv88e6xxx_g1_stats_wait(struct mv88e6xxx_chip *chip);
|
|
int mv88e6xxx_g1_stats_snapshot(struct mv88e6xxx_chip *chip, int port);
|
|
int mv88e6320_g1_stats_snapshot(struct mv88e6xxx_chip *chip, int port);
|
|
int mv88e6390_g1_stats_snapshot(struct mv88e6xxx_chip *chip, int port);
|
|
int mv88e6390_g1_stats_set_histogram(struct mv88e6xxx_chip *chip);
|
|
void mv88e6xxx_g1_stats_read(struct mv88e6xxx_chip *chip, int stat, u32 *val);
|
|
int mv88e6095_g1_set_egress_port(struct mv88e6xxx_chip *chip, int port);
|
|
int mv88e6390_g1_set_egress_port(struct mv88e6xxx_chip *chip, int port);
|
|
int mv88e6095_g1_set_cpu_port(struct mv88e6xxx_chip *chip, int port);
|
|
int mv88e6390_g1_set_cpu_port(struct mv88e6xxx_chip *chip, int port);
|
|
int mv88e6390_g1_mgmt_rsvd2cpu(struct mv88e6xxx_chip *chip);
|
|
|
|
int mv88e6xxx_g1_atu_set_learn2all(struct mv88e6xxx_chip *chip, bool learn2all);
|
|
int mv88e6xxx_g1_atu_set_age_time(struct mv88e6xxx_chip *chip,
|
|
unsigned int msecs);
|
|
|
|
#endif /* _MV88E6XXX_GLOBAL1_H */
|