1. 15 Feb, 2023 8 commits
  2. 13 Feb, 2023 3 commits
  3. 09 Feb, 2023 4 commits
  4. 07 Feb, 2023 1 commit
  5. 03 Feb, 2023 2 commits
    • Daniel Lezcano's avatar
      thermal: intel: quark_dts: Use generic trip points · 72ffc28f
      Daniel Lezcano authored
      Make the intel_quark_dts_thermal driver register an array of generic
      trip points along with the thermal zone and drop the trip points
      thermal zone callbacks that are not used any more from it.
      Signed-off-by: default avatarDaniel Lezcano <daniel.lezcano@kernel.org>
      [ rjw: Subject and changelog edits ]
      Signed-off-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
      72ffc28f
    • Srinivas Pandruvada's avatar
      thermal: intel: powerclamp: Use powercap idle-inject feature · 8526eb7f
      Srinivas Pandruvada authored
      There are two idle injection implementation in the Linux kernel. One
      via intel_powerclamp and the other using powercap/idle_inject. Both
      implementation end up in calling play_idle* function from a FIFO
      priority thread. Both can't be used at the same time.
      
      It is better to use one idle injection framework for better
      maintainability. In this way, there is only one caller for play_idle.
      
      Here powercap/idle_inject can be used for both per-core and for system
      wide idle injection. This framework has a well defined interface which
      allow registry for per-core or for all CPUs (system wide).
      
      This reduces code complexity in the intel powerclamp driver as all the
      per CPU kthreads, delayed work and calls to play_idle can be removed.
      
      The changes include:
       - Remove unneeded include files
       - Remove per CPU kthread workers: balancing_work and idle_injection_work.
       - Reuse the compensation related code by moving from previous worker
         thread to idle_injection callback.
       - Adjust the idle_duration and runtime by using powercap/idle_inject
         interface.
       - Remove all variables, which are not required once powercap/idle_inject
         is used.
       - Add mutex to avoid race during removal of idle injection during module
         unload and user action to change idle inject percent. Also for
         protection during dynamic adjustment of run and idle time from
         update() callback.
       - Remove online/offline callbacks to designate control CPU
       - Use cpu_present_mask global variable for CPU mask
       - Remove hot plug locks
      Signed-off-by: default avatarSrinivas Pandruvada <srinivas.pandruvada@linux.intel.com>
      Signed-off-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
      8526eb7f
  6. 02 Feb, 2023 16 commits
  7. 30 Jan, 2023 1 commit
    • Rafael J. Wysocki's avatar
      Merge branch 'thermal-intel' · f364beb5
      Rafael J. Wysocki authored
      Merge changes affecting thermal control on Intel platforms for 6.3-rc1:
      
       - Consolidate code accessing the Intel TCC (Thermal Control Circuitry)
         MSRs by introducing library functions for that and making the
         TCC-related code in thermal drivers use them (Zhang Rui).
      
       - Enhance the x86_pkg_temp_thermal driver to support dynamic tjmax
         changes (Zhang Rui).
      
       - Address an "unsigned expression compared with zero" warning in the
         intel_soc_dts_iosf thermal driver (Yang Li).
      
       - Update comments regarding two functions in the Intel Menlow thermal
         driver (Deming Wang).
      
       - Use sysfs_emit_at() instead of scnprintf() in the int340x thermal
         driver (ye xingchen).
      
       - Make the intel_pch thermal driver support the Wellsburg PCH (Tim
         Zimmermann).
      
       - Add trip point initialization helper functions for ACPI-defined trip
         points and modify two thermal drivers to use them (Rafael Wysocki,
         Daniel Lezcano).
      
       - Modify the intel_pch and processor_thermal_device_pci thermal drivers
         use generic trip point tables instead of thermal zone trip point
         callbacks (Daniel Lezcano).
      
       - Add production mode attribute sysfs attribute to the int340x thermal
         driver (Srinivas Pandruvada).
      
       - Rework dynamic trip point updates handling and locking in the int340x
         thermal driver (Rafael Wysocki).
      
       - Make the int340x thermal driver use a generic trip points table
         instead of thermal zone trip point callbacks (Rafael Wysocki, Daniel
         Lezcano).
      
      * thermal-intel:
        thermal: intel: int340x: Use generic trip points table
        thermal: intel: int340x: Use zone lock for synchronization
        thermal: intel: int340x: Rework updating trip points
        thermal: ACPI: Initialize trips if temperature is out of range
        thermal: intel: processor_thermal_device_pci: Use generic trip point
        thermal: intel: int340x: Add production mode attribute
        thermal: intel: intel_pch: Use generic trip points
        thermal: ACPI: Add ACPI trip point routines
        thermal: intel: intel_pch: Add support for Wellsburg PCH
        thermal: int340x_thermal: Use sysfs_emit_at() instead of scnprintf()
        thermal: intel: menlow: Update function descriptions
        thermal: intel: Fix unsigned comparison with less than zero
        thermal/x86_pkg_temp_thermal: Add support for handling dynamic tjmax
        thermal/x86_pkg_temp_thermal: Use Intel TCC library
        thermal/intel/intel_tcc_cooling: Use Intel TCC library
        thermal/intel/intel_soc_dts_iosf: Use Intel TCC library
        thermal/int340x/processor_thermal: Use Intel TCC library
        thermal/intel: Introduce Intel TCC library
      f364beb5
  8. 27 Jan, 2023 5 commits
    • Rafael J. Wysocki's avatar
      79b20270
    • Rafael J. Wysocki's avatar
      thermal: intel: int340x: Use generic trip points table · f4118dbe
      Rafael J. Wysocki authored
      Modify int340x_thermal_zone_add() to register the thermal zone along
      with a trip points table, which allows the trip-related zone callbacks
      to be dropped, because they are not needed any more.
      
      In order to consolidate the code, use ACPI trip library functions to
      populate generic trip points in int340x_thermal_read_trips() and to
      update them in int340x_thermal_update_trips().
      Signed-off-by: default avatarDaniel Lezcano <daniel.lezcano@linaro.org>
      Co-developed-by: default avatarDaniel Lezcano <daniel.lezcano@linaro.org>
      Signed-off-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
      f4118dbe
    • Rafael J. Wysocki's avatar
      thermal: intel: int340x: Use zone lock for synchronization · 9e9b7e18
      Rafael J. Wysocki authored
      Because the ->get_trip_temp() and ->get_trip_type() thermal zone
      callbacks are only invoked from __thermal_zone_get_trip() which is
      always called by the thermal core under the zone lock, it is sufficient
      for int340x_thermal_update_trips() to acquire the zone lock for mutual
      exclusion with those callbacks.
      
      Accordingly, modify int340x_thermal_update_trips() to use the zone lock
      instead of the internal trip_mutex and drop the latter which is not
      necessary any more.
      Signed-off-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
      9e9b7e18
    • Rafael J. Wysocki's avatar
      thermal: intel: int340x: Rework updating trip points · b1bf9dbf
      Rafael J. Wysocki authored
      It is generally invalid to change the trip point indices after they have
      been exposed via sysfs.
      
      Moreover, the thermal objects in the ACPI namespace cannot go away and
      appear on the fly.  In practice, the only thing that can happen when the
      INT3403_PERF_TRIP_POINT_CHANGED notification is sent by the platform
      firmware is a change of the return values of those thermal objects.
      
      For this reason, add a special function for updating the trip point
      temperatures after re-evaluating the respective ACPI thermal objects
      and change int3403_notify() to invoke it instead of
      int340x_thermal_read_trips() that would change the trip point indices
      on errors.  Also remove the locking from the latter, because it is only
      called before registering the thermal zone and it cannot race with the
      zone's callbacks.
      Signed-off-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
      b1bf9dbf
    • Rafael J. Wysocki's avatar
      thermal: ACPI: Initialize trips if temperature is out of range · 97efecfd
      Rafael J. Wysocki authored
      In some cases it is still useful to register a trip point if the
      temperature returned by the corresponding ACPI thermal object (for
      example, _HOT) is invalid to start with, because the same ACPI
      thermal object may start to return a valid temperature after a
      system configuration change (for example, from an AC power source
      to battery an vice versa).
      
      For this reason, if the ACPI thermal object evaluated by
      thermal_acpi_trip_init() successfully returns a temperature value that
      is out of the range of values taken into account, initialize the trip
      point using THERMAL_TEMP_INVALID as the temperature value instead of
      returning an error to allow the user of the trip point to decide what
      to do with it.
      
      Also update pch_wpt_add_acpi_psv_trip() to reject trip points with
      invalid temperature values.
      
      Fixes: 7a0e3974 ("thermal: ACPI: Add ACPI trip point routines")
      Reported-by: default avatarSrinivas Pandruvada <srinivas.pandruvada@linux.intel.com>
      Signed-off-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
      97efecfd