static int
 mlxsw_thermal_module_trips_update(struct device *dev, struct mlxsw_core *core,
-                                 struct mlxsw_thermal_module *tz)
+                                 struct mlxsw_thermal_module *tz,
+                                 int crit_temp, int emerg_temp)
 {
-       int crit_temp, emerg_temp;
        int err;
 
-       err = mlxsw_env_module_temp_thresholds_get(core, tz->module,
-                                                  SFP_TEMP_HIGH_WARN,
-                                                  &crit_temp);
-       if (err)
-               return err;
+       /* Do not try to query temperature thresholds directly from the module's
+        * EEPROM if we got valid thresholds from MTMP.
+        */
+       if (!emerg_temp || !crit_temp) {
+               err = mlxsw_env_module_temp_thresholds_get(core, tz->module,
+                                                          SFP_TEMP_HIGH_WARN,
+                                                          &crit_temp);
+               if (err)
+                       return err;
 
-       err = mlxsw_env_module_temp_thresholds_get(core, tz->module,
-                                                  SFP_TEMP_HIGH_ALARM,
-                                                  &emerg_temp);
-       if (err)
-               return err;
+               err = mlxsw_env_module_temp_thresholds_get(core, tz->module,
+                                                          SFP_TEMP_HIGH_ALARM,
+                                                          &emerg_temp);
+               if (err)
+                       return err;
+       }
 
        if (crit_temp > emerg_temp) {
                dev_warn(dev, "%s : Critical threshold %d is above emergency threshold %d\n",
 {
        struct mlxsw_thermal_module *tz = tzdev->devdata;
        struct mlxsw_thermal *thermal = tz->parent;
+       int temp, crit_temp, emerg_temp;
        struct device *dev;
        u16 sensor_index;
-       int temp;
        int err;
 
        dev = thermal->bus_info->dev;
 
        /* Read module temperature and thresholds. */
        mlxsw_thermal_module_temp_and_thresholds_get(thermal->core,
-                                                    sensor_index, &temp, NULL,
-                                                    NULL);
+                                                    sensor_index, &temp,
+                                                    &crit_temp, &emerg_temp);
        *p_temp = temp;
 
        if (!temp)
                return 0;
 
        /* Update trip points. */
-       err = mlxsw_thermal_module_trips_update(dev, thermal->core, tz);
+       err = mlxsw_thermal_module_trips_update(dev, thermal->core, tz,
+                                               crit_temp, emerg_temp);
        if (!err && temp > 0)
                mlxsw_thermal_tz_score_update(thermal, tzdev, tz->trips, temp);
 
                          struct mlxsw_thermal *thermal, u8 module)
 {
        struct mlxsw_thermal_module *module_tz;
+       int crit_temp, emerg_temp;
+       u16 sensor_index;
 
+       sensor_index = MLXSW_REG_MTMP_MODULE_INDEX_MIN + module;
        module_tz = &thermal->tz_module_arr[module];
        /* Skip if parent is already set (case of port split). */
        if (module_tz->parent)
               sizeof(thermal->trips));
        /* Initialize all trip point. */
        mlxsw_thermal_module_trips_reset(module_tz);
+       /* Read module temperature and thresholds. */
+       mlxsw_thermal_module_temp_and_thresholds_get(core, sensor_index, NULL,
+                                                    &crit_temp, &emerg_temp);
        /* Update trip point according to the module data. */
-       return mlxsw_thermal_module_trips_update(dev, core, module_tz);
+       return mlxsw_thermal_module_trips_update(dev, core, module_tz,
+                                                crit_temp, emerg_temp);
 }
 
 static void mlxsw_thermal_module_fini(struct mlxsw_thermal_module *module_tz)