Lines Matching full:sparx5

2 /* Microchip Sparx5 Switch driver
201 static void sparx5_get_queue_sys_stats(struct sparx5 *sparx5, int portno) in sparx5_get_queue_sys_stats() argument
208 portstats = &sparx5->stats[portno * sparx5->num_stats]; in sparx5_get_queue_sys_stats()
209 mutex_lock(&sparx5->queue_stats_lock); in sparx5_get_queue_sys_stats()
210 spx5_wr(XQS_STAT_CFG_STAT_VIEW_SET(portno), sparx5, XQS_STAT_CFG); in sparx5_get_queue_sys_stats()
214 sparx5_update_counter(stats, spx5_rd(sparx5, XQS_CNT(addr))); in sparx5_get_queue_sys_stats()
218 sparx5_update_counter(stats, spx5_rd(sparx5, XQS_CNT(addr))); in sparx5_get_queue_sys_stats()
222 sparx5_update_counter(stats, spx5_rd(sparx5, XQS_CNT(addr))); in sparx5_get_queue_sys_stats()
224 spx5_rd(sparx5, XQS_CNT(32))); in sparx5_get_queue_sys_stats()
226 spx5_rd(sparx5, XQS_CNT(272))); in sparx5_get_queue_sys_stats()
227 mutex_unlock(&sparx5->queue_stats_lock); in sparx5_get_queue_sys_stats()
230 static void sparx5_get_ana_ac_stats_stats(struct sparx5 *sparx5, int portno) in sparx5_get_ana_ac_stats_stats() argument
232 u64 *portstats = &sparx5->stats[portno * sparx5->num_stats]; in sparx5_get_ana_ac_stats_stats()
235 spx5_rd(sparx5, ANA_AC_PORT_STAT_LSB_CNT(portno, in sparx5_get_ana_ac_stats_stats()
505 static void sparx5_get_device_stats(struct sparx5 *sparx5, int portno) in sparx5_get_device_stats() argument
507 u64 *portstats = &sparx5->stats[portno * sparx5->num_stats]; in sparx5_get_device_stats()
512 inst = spx5_inst_get(sparx5, dev, tinst); in sparx5_get_device_stats()
788 static void sparx5_get_asm_stats(struct sparx5 *sparx5, int portno) in sparx5_get_asm_stats() argument
790 u64 *portstats = &sparx5->stats[portno * sparx5->num_stats]; in sparx5_get_asm_stats()
791 void __iomem *inst = spx5_inst_get(sparx5, TARGET_ASM, 0); in sparx5_get_asm_stats()
815 struct sparx5 *sparx5 = port->sparx5; in sparx5_get_eth_phy_stats() local
820 portstats = &sparx5->stats[portno * sparx5->num_stats]; in sparx5_get_eth_phy_stats()
825 inst = spx5_inst_get(sparx5, dev, tinst); in sparx5_get_eth_phy_stats()
828 inst = spx5_inst_get(sparx5, TARGET_ASM, 0); in sparx5_get_eth_phy_stats()
840 struct sparx5 *sparx5 = port->sparx5; in sparx5_get_eth_mac_stats() local
845 portstats = &sparx5->stats[portno * sparx5->num_stats]; in sparx5_get_eth_mac_stats()
850 inst = spx5_inst_get(sparx5, dev, tinst); in sparx5_get_eth_mac_stats()
853 inst = spx5_inst_get(sparx5, TARGET_ASM, 0); in sparx5_get_eth_mac_stats()
908 struct sparx5 *sparx5 = port->sparx5; in sparx5_get_eth_mac_ctrl_stats() local
913 portstats = &sparx5->stats[portno * sparx5->num_stats]; in sparx5_get_eth_mac_ctrl_stats()
918 inst = spx5_inst_get(sparx5, dev, tinst); in sparx5_get_eth_mac_ctrl_stats()
921 inst = spx5_inst_get(sparx5, TARGET_ASM, 0); in sparx5_get_eth_mac_ctrl_stats()
940 struct sparx5 *sparx5 = port->sparx5; in sparx5_get_eth_rmon_stats() local
945 portstats = &sparx5->stats[portno * sparx5->num_stats]; in sparx5_get_eth_rmon_stats()
950 inst = spx5_inst_get(sparx5, dev, tinst); in sparx5_get_eth_rmon_stats()
953 inst = spx5_inst_get(sparx5, TARGET_ASM, 0); in sparx5_get_eth_rmon_stats()
998 struct sparx5 *sparx5 = port->sparx5; in sparx5_get_sset_count() local
1002 return sparx5->num_ethtool_stats; in sparx5_get_sset_count()
1008 struct sparx5 *sparx5 = port->sparx5; in sparx5_get_sset_strings() local
1014 for (idx = 0; idx < sparx5->num_ethtool_stats; idx++) in sparx5_get_sset_strings()
1016 sparx5->stats_layout[idx], ETH_GSTRING_LEN); in sparx5_get_sset_strings()
1023 struct sparx5 *sparx5 = port->sparx5; in sparx5_get_sset_data() local
1029 portstats = &sparx5->stats[portno * sparx5->num_stats]; in sparx5_get_sset_data()
1034 inst = spx5_inst_get(sparx5, dev, tinst); in sparx5_get_sset_data()
1037 inst = spx5_inst_get(sparx5, TARGET_ASM, 0); in sparx5_get_sset_data()
1040 sparx5_get_ana_ac_stats_stats(sparx5, portno); in sparx5_get_sset_data()
1041 sparx5_get_queue_sys_stats(sparx5, portno); in sparx5_get_sset_data()
1045 sparx5->num_ethtool_stats; idx++) in sparx5_get_sset_data()
1053 struct sparx5 *sparx5 = port->sparx5; in sparx5_get_stats64() local
1057 if (!sparx5->stats) in sparx5_get_stats64()
1060 portstats = &sparx5->stats[port->portno * sparx5->num_stats]; in sparx5_get_stats64()
1112 static void sparx5_update_port_stats(struct sparx5 *sparx5, int portno) in sparx5_update_port_stats() argument
1114 if (sparx5_is_baser(sparx5->ports[portno]->conf.portmode)) in sparx5_update_port_stats()
1115 sparx5_get_device_stats(sparx5, portno); in sparx5_update_port_stats()
1117 sparx5_get_asm_stats(sparx5, portno); in sparx5_update_port_stats()
1118 sparx5_get_ana_ac_stats_stats(sparx5, portno); in sparx5_update_port_stats()
1119 sparx5_get_queue_sys_stats(sparx5, portno); in sparx5_update_port_stats()
1122 static void sparx5_update_stats(struct sparx5 *sparx5) in sparx5_update_stats() argument
1127 if (sparx5->ports[idx]) in sparx5_update_stats()
1128 sparx5_update_port_stats(sparx5, idx); in sparx5_update_stats()
1134 struct sparx5 *sparx5 = container_of(dwork, in sparx5_check_stats_work() local
1135 struct sparx5, in sparx5_check_stats_work()
1138 sparx5_update_stats(sparx5); in sparx5_check_stats_work()
1140 queue_delayed_work(sparx5->stats_queue, &sparx5->stats_work, in sparx5_check_stats_work()
1160 static void sparx5_config_stats(struct sparx5 *sparx5) in sparx5_config_stats() argument
1165 sparx5, in sparx5_config_stats()
1169 static void sparx5_config_port_stats(struct sparx5 *sparx5, int portno) in sparx5_config_port_stats() argument
1173 XQS_STAT_CFG_STAT_CLEAR_SHOT_SET(3), sparx5, in sparx5_config_port_stats()
1183 sparx5, ANA_AC_PORT_STAT_CFG(portno, SPX5_PORT_POLICER_DROPS)); in sparx5_config_port_stats()
1190 struct sparx5 *sparx5 = port->sparx5; in sparx5_get_ts_info() local
1193 if (!sparx5->ptp) in sparx5_get_ts_info()
1196 phc = &sparx5->phc[SPARX5_PHC_PORT]; in sparx5_get_ts_info()
1233 int sparx_stats_init(struct sparx5 *sparx5) in sparx_stats_init() argument
1238 sparx5->stats_layout = sparx5_stats_layout; in sparx_stats_init()
1239 sparx5->num_stats = spx5_stats_count; in sparx_stats_init()
1240 sparx5->num_ethtool_stats = ARRAY_SIZE(sparx5_stats_layout); in sparx_stats_init()
1241 sparx5->stats = devm_kcalloc(sparx5->dev, in sparx_stats_init()
1242 SPX5_PORTS_ALL * sparx5->num_stats, in sparx_stats_init()
1244 if (!sparx5->stats) in sparx_stats_init()
1247 mutex_init(&sparx5->queue_stats_lock); in sparx_stats_init()
1248 sparx5_config_stats(sparx5); in sparx_stats_init()
1250 if (sparx5->ports[portno]) in sparx_stats_init()
1251 sparx5_config_port_stats(sparx5, portno); in sparx_stats_init()
1254 dev_name(sparx5->dev)); in sparx_stats_init()
1255 sparx5->stats_queue = create_singlethread_workqueue(queue_name); in sparx_stats_init()
1256 if (!sparx5->stats_queue) in sparx_stats_init()
1259 INIT_DELAYED_WORK(&sparx5->stats_work, sparx5_check_stats_work); in sparx_stats_init()
1260 queue_delayed_work(sparx5->stats_queue, &sparx5->stats_work, in sparx_stats_init()