const struct thermal_trip *trip,
                              bool crossed_up)
 {
+       const struct thermal_trip_desc *td = trip_to_trip_desc(trip);
        struct thermal_instance *instance;
 
        lockdep_assert_held(&tz->lock);
                thermal_zone_trip_id(tz, trip), trip->temperature,
                tz->temperature, trip->hysteresis);
 
-       list_for_each_entry(instance, &tz->thermal_instances, tz_node) {
-               if (instance->trip == trip)
-                       bang_bang_set_instance_target(instance, crossed_up);
-       }
+       list_for_each_entry(instance, &td->thermal_instances, trip_node)
+               bang_bang_set_instance_target(instance, crossed_up);
 }
 
 static void bang_bang_manage(struct thermal_zone_device *tz)
                 * to the thermal zone temperature and the trip point threshold.
                 */
                turn_on = tz->temperature >= td->threshold;
-               list_for_each_entry(instance, &tz->thermal_instances, tz_node) {
-                       if (!instance->initialized && instance->trip == trip)
+               list_for_each_entry(instance, &td->thermal_instances, trip_node) {
+                       if (!instance->initialized)
                                bang_bang_set_instance_target(instance, turn_on);
                }
        }
 
 /**
  * fair_share_throttle - throttles devices associated with the given zone
  * @tz: thermal_zone_device
- * @trip: trip point
+ * @td: trip point descriptor
  * @trip_level: number of trips crossed by the zone temperature
  *
  * Throttling Logic: This uses three parameters to calculate the new
  * new_state of cooling device = P3 * P2 * P1
  */
 static void fair_share_throttle(struct thermal_zone_device *tz,
-                               const struct thermal_trip *trip,
+                               const struct thermal_trip_desc *td,
                                int trip_level)
 {
        struct thermal_instance *instance;
        int total_weight = 0;
        int nr_instances = 0;
 
-       list_for_each_entry(instance, &tz->thermal_instances, tz_node) {
-               if (instance->trip != trip)
-                       continue;
-
+       list_for_each_entry(instance, &td->thermal_instances, trip_node) {
                total_weight += instance->weight;
                nr_instances++;
        }
 
-       list_for_each_entry(instance, &tz->thermal_instances, tz_node) {
+       list_for_each_entry(instance, &td->thermal_instances, trip_node) {
                struct thermal_cooling_device *cdev = instance->cdev;
                u64 dividend;
                u32 divisor;
 
-               if (instance->trip != trip)
-                       continue;
-
                dividend = trip_level;
                dividend *= cdev->max_state;
                divisor = tz->num_trips;
                    trip->type == THERMAL_TRIP_HOT)
                        continue;
 
-               fair_share_throttle(tz, trip, trip_level);
+               fair_share_throttle(tz, td, trip_level);
        }
 }
 
 
        struct power_actor *power;
 };
 
-static bool power_actor_is_valid(struct power_allocator_params *params,
-                                struct thermal_instance *instance)
+static bool power_actor_is_valid(struct thermal_instance *instance)
 {
-       return (instance->trip == params->trip_max &&
-                cdev_is_power_actor(instance->cdev));
+       return cdev_is_power_actor(instance->cdev);
 }
 
 /**
 static u32 estimate_sustainable_power(struct thermal_zone_device *tz)
 {
        struct power_allocator_params *params = tz->governor_data;
+       const struct thermal_trip_desc *td = trip_to_trip_desc(params->trip_max);
        struct thermal_cooling_device *cdev;
        struct thermal_instance *instance;
        u32 sustainable_power = 0;
        u32 min_power;
 
-       list_for_each_entry(instance, &tz->thermal_instances, tz_node) {
-               if (!power_actor_is_valid(params, instance))
+       list_for_each_entry(instance, &td->thermal_instances, trip_node) {
+               if (!power_actor_is_valid(instance))
                        continue;
 
                cdev = instance->cdev;
 static void allocate_power(struct thermal_zone_device *tz, int control_temp)
 {
        struct power_allocator_params *params = tz->governor_data;
+       const struct thermal_trip_desc *td = trip_to_trip_desc(params->trip_max);
        unsigned int num_actors = params->num_actors;
        struct power_actor *power = params->power;
        struct thermal_cooling_device *cdev;
        /* Clean all buffers for new power estimations */
        memset(power, 0, params->buffer_size);
 
-       list_for_each_entry(instance, &tz->thermal_instances, tz_node) {
+       list_for_each_entry(instance, &td->thermal_instances, trip_node) {
                struct power_actor *pa = &power[i];
 
-               if (!power_actor_is_valid(params, instance))
+               if (!power_actor_is_valid(instance))
                        continue;
 
                cdev = instance->cdev;
                       power_range);
 
        i = 0;
-       list_for_each_entry(instance, &tz->thermal_instances, tz_node) {
+       list_for_each_entry(instance, &td->thermal_instances, trip_node) {
                struct power_actor *pa = &power[i];
 
-               if (!power_actor_is_valid(params, instance))
+               if (!power_actor_is_valid(instance))
                        continue;
 
                power_actor_set_power(instance->cdev, instance,
 static void allow_maximum_power(struct thermal_zone_device *tz)
 {
        struct power_allocator_params *params = tz->governor_data;
+       const struct thermal_trip_desc *td = trip_to_trip_desc(params->trip_max);
        struct thermal_cooling_device *cdev;
        struct thermal_instance *instance;
        u32 req_power;
 
-       list_for_each_entry(instance, &tz->thermal_instances, tz_node) {
-               if (!power_actor_is_valid(params, instance))
+       list_for_each_entry(instance, &td->thermal_instances, trip_node) {
+               if (!power_actor_is_valid(instance))
                        continue;
 
                cdev = instance->cdev;
 static int check_power_actors(struct thermal_zone_device *tz,
                              struct power_allocator_params *params)
 {
+       const struct thermal_trip_desc *td = trip_to_trip_desc(params->trip_max);
        struct thermal_instance *instance;
        int ret = 0;
 
-       list_for_each_entry(instance, &tz->thermal_instances, tz_node) {
-               if (instance->trip != params->trip_max)
-                       continue;
-
+       list_for_each_entry(instance, &td->thermal_instances, trip_node) {
                if (!cdev_is_power_actor(instance->cdev)) {
                        dev_warn(&tz->device, "power_allocator: %s is not a power actor\n",
                                 instance->cdev->type);
                                      enum thermal_notify_event reason)
 {
        struct power_allocator_params *params = tz->governor_data;
+       const struct thermal_trip_desc *td = trip_to_trip_desc(params->trip_max);
        struct thermal_instance *instance;
        int num_actors = 0;
 
        switch (reason) {
        case THERMAL_TZ_BIND_CDEV:
        case THERMAL_TZ_UNBIND_CDEV:
-               list_for_each_entry(instance, &tz->thermal_instances, tz_node)
-                       if (power_actor_is_valid(params, instance))
+               list_for_each_entry(instance, &td->thermal_instances, trip_node)
+                       if (power_actor_is_valid(instance))
                                num_actors++;
 
                if (num_actors == params->num_actors)
                break;
        case THERMAL_INSTANCE_WEIGHT_CHANGED:
                params->total_weight = 0;
-               list_for_each_entry(instance, &tz->thermal_instances, tz_node)
-                       if (power_actor_is_valid(params, instance))
+               list_for_each_entry(instance, &td->thermal_instances, trip_node)
+                       if (power_actor_is_valid(instance))
                                params->total_weight += instance->weight;
                break;
        default:
 
 }
 
 static void thermal_zone_trip_update(struct thermal_zone_device *tz,
-                                    const struct thermal_trip *trip,
+                                    const struct thermal_trip_desc *td,
                                     int trip_threshold)
 {
+       const struct thermal_trip *trip = &td->trip;
        enum thermal_trend trend = get_tz_trend(tz, trip);
        int trip_id = thermal_zone_trip_id(tz, trip);
        struct thermal_instance *instance;
        dev_dbg(&tz->device, "Trip%d[type=%d,temp=%d]:trend=%d,throttle=%d\n",
                trip_id, trip->type, trip_threshold, trend, throttle);
 
-       list_for_each_entry(instance, &tz->thermal_instances, tz_node) {
+       list_for_each_entry(instance, &td->thermal_instances, trip_node) {
                int old_target;
 
-               if (instance->trip != trip)
-                       continue;
-
                old_target = instance->target;
                instance->target = get_target_state(instance, trend, throttle);
 
                    trip->type == THERMAL_TRIP_HOT)
                        continue;
 
-               thermal_zone_trip_update(tz, trip, td->threshold);
+               thermal_zone_trip_update(tz, td, td->threshold);
        }
 
-       list_for_each_entry(instance, &tz->thermal_instances, tz_node)
-               thermal_cdev_update(instance->cdev);
+       for_each_trip_desc(tz, td) {
+               list_for_each_entry(instance, &td->thermal_instances, trip_node)
+                       thermal_cdev_update(instance->cdev);
+       }
 }
 
 static struct thermal_governor thermal_gov_step_wise = {
 
 
 static void thermal_zone_device_init(struct thermal_zone_device *tz)
 {
-       struct thermal_instance *pos;
+       struct thermal_trip_desc *td;
 
        INIT_DELAYED_WORK(&tz->poll_queue, thermal_zone_device_check);
 
        tz->passive = 0;
        tz->prev_low_trip = -INT_MAX;
        tz->prev_high_trip = INT_MAX;
-       list_for_each_entry(pos, &tz->thermal_instances, tz_node)
-               pos->initialized = false;
+       for_each_trip_desc(tz, td) {
+               struct thermal_instance *instance;
+
+               list_for_each_entry(instance, &td->thermal_instances, trip_node)
+                       instance->initialized = false;
+       }
 }
 
 static void thermal_governor_trip_crossed(struct thermal_governor *governor,
  * Return: 0 on success, the proper error value otherwise.
  */
 static int thermal_bind_cdev_to_trip(struct thermal_zone_device *tz,
-                                    const struct thermal_trip *trip,
+                                    struct thermal_trip *trip,
                                     struct thermal_cooling_device *cdev,
                                     struct cooling_spec *cool_spec)
 {
-       struct thermal_instance *dev;
-       struct thermal_instance *pos;
+       struct thermal_trip_desc *td = trip_to_trip_desc(trip);
+       struct thermal_instance *dev, *instance;
        bool upper_no_limit;
        int result;
 
                goto remove_trip_file;
 
        mutex_lock(&cdev->lock);
-       list_for_each_entry(pos, &tz->thermal_instances, tz_node)
-               if (pos->trip == trip && pos->cdev == cdev) {
+       list_for_each_entry(instance, &td->thermal_instances, trip_node)
+               if (instance->cdev == cdev) {
                        result = -EEXIST;
                        break;
                }
        if (!result) {
-               list_add_tail(&dev->tz_node, &tz->thermal_instances);
+               list_add_tail(&dev->trip_node, &td->thermal_instances);
                list_add_tail(&dev->cdev_node, &cdev->thermal_instances);
 
                thermal_governor_update_tz(tz, THERMAL_TZ_BIND_CDEV);
  * This function is usually called in the thermal zone device .unbind callback.
  */
 static void thermal_unbind_cdev_from_trip(struct thermal_zone_device *tz,
-                                         const struct thermal_trip *trip,
+                                         struct thermal_trip *trip,
                                          struct thermal_cooling_device *cdev)
 {
+       struct thermal_trip_desc *td = trip_to_trip_desc(trip);
        struct thermal_instance *pos, *next;
 
        mutex_lock(&cdev->lock);
-       list_for_each_entry_safe(pos, next, &tz->thermal_instances, tz_node) {
-               if (pos->trip == trip && pos->cdev == cdev) {
-                       list_del(&pos->tz_node);
+       list_for_each_entry_safe(pos, next, &td->thermal_instances, trip_node) {
+               if (pos->cdev == cdev) {
+                       list_del(&pos->trip_node);
                        list_del(&pos->cdev_node);
 
                        thermal_governor_update_tz(tz, THERMAL_TZ_UNBIND_CDEV);
                }
        }
 
-       INIT_LIST_HEAD(&tz->thermal_instances);
        INIT_LIST_HEAD(&tz->node);
        ida_init(&tz->ida);
        mutex_init(&tz->lock);
        tz->num_trips = num_trips;
        for_each_trip_desc(tz, td) {
                td->trip = *trip++;
+               INIT_LIST_HEAD(&td->thermal_instances);
                /*
                 * Mark all thresholds as invalid to start with even though
                 * this only matters for the trips that start as invalid and
 
        struct thermal_trip trip;
        struct thermal_trip_attrs trip_attrs;
        struct list_head notify_list_node;
+       struct list_head thermal_instances;
        int notify_temp;
        int threshold;
 };
  * @tzp:       thermal zone parameters
  * @governor:  pointer to the governor for this thermal zone
  * @governor_data:     private pointer for governor data
- * @thermal_instances: list of &struct thermal_instance of this thermal zone
  * @ida:       &struct ida to generate unique id for this zone's cooling
  *             devices
  * @lock:      lock to protect thermal_instances list
        struct thermal_zone_params *tzp;
        struct thermal_governor *governor;
        void *governor_data;
-       struct list_head thermal_instances;
        struct ida ida;
        struct mutex lock;
        struct list_head node;
        struct device_attribute attr;
        char weight_attr_name[THERMAL_NAME_LENGTH];
        struct device_attribute weight_attr;
-       struct list_head tz_node; /* node in tz->thermal_instances */
+       struct list_head trip_node; /* node in trip->thermal_instances */
        struct list_head cdev_node; /* node in cdev->thermal_instances */
        unsigned int weight; /* The weight of the cooling device */
        bool upper_no_limit;
 
                                     struct thermal_cooling_device *cdev,
                                     const struct thermal_trip *trip)
 {
+       const struct thermal_trip_desc *td = trip_to_trip_desc(trip);
        struct thermal_instance *ti;
 
-       list_for_each_entry(ti, &tz->thermal_instances, tz_node) {
-               if (ti->trip == trip && ti->cdev == cdev)
+       list_for_each_entry(ti, &td->thermal_instances, trip_node) {
+               if (ti->cdev == cdev)
                        return true;
        }