2 * Copyright (c) 2007-2015 Solarflare Communications Inc.
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions are met:
8 * 1. Redistributions of source code must retain the above copyright notice,
9 * this list of conditions and the following disclaimer.
10 * 2. Redistributions in binary form must reproduce the above copyright notice,
11 * this list of conditions and the following disclaimer in the documentation
12 * and/or other materials provided with the distribution.
14 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
15 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
16 * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
17 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
18 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
19 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
20 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
21 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
22 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
23 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
24 * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26 * The views and conclusions contained in the software and documentation are
27 * those of the authors and should not be interpreted as representing official
28 * policies, either expressed or implied, of the FreeBSD Project.
31 #include <sys/cdefs.h>
32 __FBSDID("$FreeBSD$");
37 #if EFSYS_OPT_MON_NULL
41 #if EFSYS_OPT_MON_LM87
45 #if EFSYS_OPT_MON_MAX6647
49 #if EFSYS_OPT_MON_MCDI
55 static const char *__efx_mon_name[] = {
69 efx_nic_cfg_t *encp = &(enp->en_nic_cfg);
71 EFSYS_ASSERT3U(enp->en_magic, ==, EFX_NIC_MAGIC);
73 EFSYS_ASSERT(encp->enc_mon_type != EFX_MON_INVALID);
74 EFSYS_ASSERT3U(encp->enc_mon_type, <, EFX_MON_NTYPES);
75 return (__efx_mon_name[encp->enc_mon_type]);
78 #endif /* EFSYS_OPT_NAMES */
80 #if EFSYS_OPT_MON_NULL
81 static efx_mon_ops_t __efx_mon_null_ops = {
82 nullmon_reset, /* emo_reset */
83 nullmon_reconfigure, /* emo_reconfigure */
84 #if EFSYS_OPT_MON_STATS
85 nullmon_stats_update /* emo_stats_update */
86 #endif /* EFSYS_OPT_MON_STATS */
90 #if EFSYS_OPT_MON_LM87
91 static efx_mon_ops_t __efx_mon_lm87_ops = {
92 lm87_reset, /* emo_reset */
93 lm87_reconfigure, /* emo_reconfigure */
94 #if EFSYS_OPT_MON_STATS
95 lm87_stats_update /* emo_stats_update */
96 #endif /* EFSYS_OPT_MON_STATS */
100 #if EFSYS_OPT_MON_MAX6647
101 static efx_mon_ops_t __efx_mon_max6647_ops = {
102 max6647_reset, /* emo_reset */
103 max6647_reconfigure, /* emo_reconfigure */
104 #if EFSYS_OPT_MON_STATS
105 max6647_stats_update /* emo_stats_update */
106 #endif /* EFSYS_OPT_MON_STATS */
110 #if EFSYS_OPT_MON_MCDI
111 static efx_mon_ops_t __efx_mon_mcdi_ops = {
112 NULL, /* emo_reset */
113 NULL, /* emo_reconfigure */
114 #if EFSYS_OPT_MON_STATS
115 mcdi_mon_stats_update /* emo_stats_update */
116 #endif /* EFSYS_OPT_MON_STATS */
121 __checkReturn efx_rc_t
125 efx_nic_cfg_t *encp = &(enp->en_nic_cfg);
126 efx_mon_t *emp = &(enp->en_mon);
130 EFSYS_ASSERT3U(enp->en_magic, ==, EFX_NIC_MAGIC);
131 EFSYS_ASSERT3U(enp->en_mod_flags, &, EFX_MOD_PROBE);
133 if (enp->en_mod_flags & EFX_MOD_MON) {
138 enp->en_mod_flags |= EFX_MOD_MON;
140 emp->em_type = encp->enc_mon_type;
142 EFSYS_ASSERT(encp->enc_mon_type != EFX_MON_INVALID);
143 switch (emp->em_type) {
144 #if EFSYS_OPT_MON_NULL
146 emop = &__efx_mon_null_ops;
149 #if EFSYS_OPT_MON_LM87
151 emop = &__efx_mon_lm87_ops;
154 #if EFSYS_OPT_MON_MAX6647
155 case EFX_MON_MAX6647:
156 emop = &__efx_mon_max6647_ops;
159 #if EFSYS_OPT_MON_MCDI
160 case EFX_MON_SFC90X0:
161 case EFX_MON_SFC91X0:
162 case EFX_MON_SFC92X0:
163 emop = &__efx_mon_mcdi_ops;
171 if (emop->emo_reset != NULL) {
172 if ((rc = emop->emo_reset(enp)) != 0)
176 if (emop->emo_reconfigure != NULL) {
177 if ((rc = emop->emo_reconfigure(enp)) != 0)
187 if (emop->emo_reset != NULL)
188 (void) emop->emo_reset(enp);
195 emp->em_type = EFX_MON_INVALID;
197 enp->en_mod_flags &= ~EFX_MOD_MON;
200 EFSYS_PROBE1(fail1, efx_rc_t, rc);
205 #if EFSYS_OPT_MON_STATS
209 /* START MKCONFIG GENERATED MonitorStatNamesBlock 01ee3ea01f23a0c4 */
210 static const char *__mon_stat_name[] = {
221 "controller_cooling",
231 "psu_aoe_temperature",
246 "controller_temperature2",
248 "vreg_0_9v_temperature",
249 "vreg_1_2v_temperature",
251 "controller_internal_adc_temperature",
253 "controller_external_adc_temperature",
254 "ambient_temperature",
257 "vdd08d_vss08d_csr_extadc",
258 "hotpoint_temperature",
259 "phy_power_switch_port0",
260 "phy_power_switch_port1",
268 "ccom_avreg_1v2_supply",
269 "ccom_avreg_1v2_supply_ext_adc",
270 "ccom_avreg_1v8_supply",
271 "ccom_avreg_1v8_supply_ext_adc",
272 "controller_master_vptat",
273 "controller_master_internal_temp",
274 "controller_master_vptat_ext_adc",
275 "controller_master_internal_temp_ext_adc",
276 "controller_slave_vptat",
277 "controller_slave_internal_temp",
278 "controller_slave_vptat_ext_adc",
279 "controller_slave_internal_temp_ext_adc",
285 "controller_tdiode_temp",
288 /* END MKCONFIG GENERATED MonitorStatNamesBlock */
293 __in efx_mon_stat_t id)
295 _NOTE(ARGUNUSED(enp))
296 EFSYS_ASSERT3U(enp->en_magic, ==, EFX_NIC_MAGIC);
298 EFSYS_ASSERT3U(id, <, EFX_MON_NSTATS);
299 return (__mon_stat_name[id]);
302 #endif /* EFSYS_OPT_NAMES */
304 __checkReturn efx_rc_t
305 efx_mon_stats_update(
307 __in efsys_mem_t *esmp,
308 __inout_ecount(EFX_MON_NSTATS) efx_mon_stat_value_t *values)
310 efx_mon_t *emp = &(enp->en_mon);
311 efx_mon_ops_t *emop = emp->em_emop;
313 EFSYS_ASSERT3U(enp->en_magic, ==, EFX_NIC_MAGIC);
314 EFSYS_ASSERT3U(enp->en_mod_flags, &, EFX_MOD_MON);
316 return (emop->emo_stats_update(enp, esmp, values));
319 #endif /* EFSYS_OPT_MON_STATS */
325 efx_mon_t *emp = &(enp->en_mon);
326 efx_mon_ops_t *emop = emp->em_emop;
329 EFSYS_ASSERT3U(enp->en_magic, ==, EFX_NIC_MAGIC);
330 EFSYS_ASSERT3U(enp->en_mod_flags, &, EFX_MOD_PROBE);
331 EFSYS_ASSERT3U(enp->en_mod_flags, &, EFX_MOD_MON);
335 if (emop->emo_reset != NULL) {
336 rc = emop->emo_reset(enp);
338 EFSYS_PROBE1(fail1, efx_rc_t, rc);
341 emp->em_type = EFX_MON_INVALID;
343 enp->en_mod_flags &= ~EFX_MOD_MON;