summaryrefslogtreecommitdiff
path: root/mali-midgard-16.0/ipa/mali_kbase_ipa_generic.c
diff options
context:
space:
mode:
Diffstat (limited to 'mali-midgard-16.0/ipa/mali_kbase_ipa_generic.c')
-rw-r--r--mali-midgard-16.0/ipa/mali_kbase_ipa_generic.c217
1 files changed, 0 insertions, 217 deletions
diff --git a/mali-midgard-16.0/ipa/mali_kbase_ipa_generic.c b/mali-midgard-16.0/ipa/mali_kbase_ipa_generic.c
deleted file mode 100644
index 18fb2b2..0000000
--- a/mali-midgard-16.0/ipa/mali_kbase_ipa_generic.c
+++ /dev/null
@@ -1,217 +0,0 @@
-/*
- *
- * (C) COPYRIGHT 2016 ARM Limited. All rights reserved.
- *
- * This program is free software and is provided to you under the terms of the
- * GNU General Public License version 2 as published by the Free Software
- * Foundation, and any use by you of this program is subject to the terms
- * of such GNU licence.
- *
- * A copy of the licence is included with the program, and can also be obtained
- * from Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
- * Boston, MA 02110-1301, USA.
- *
- */
-
-
-
-#include <linux/thermal.h>
-#ifdef CONFIG_DEVFREQ_THERMAL
-#include <linux/devfreq_cooling.h>
-#endif
-#include <linux/of.h>
-
-#include "mali_kbase.h"
-#include "mali_kbase_defs.h"
-
-/*
- * This model is primarily designed for the Juno platform. It may not be
- * suitable for other platforms. The additional resources in this model
- * should preferably be minimal, as this model is rarely used when a dynamic
- * model is available.
- */
-
-/**
- * struct kbase_ipa_model_generic_data - IPA context per device
- * @dynamic_coefficient: dynamic coefficient of the model
- * @static_coefficient: static coefficient of the model
- * @ts: ts of the model
- * @gpu_tz: thermal zone device
- * @ipa_lock: protects the entire IPA context
- */
-
-struct kbase_ipa_model_generic_data {
- u32 dynamic_coefficient;
- u32 static_coefficient;
- s32 ts[4];
- struct thermal_zone_device *gpu_tz;
- struct mutex ipa_lock;
-};
-#define FALLBACK_STATIC_TEMPERATURE 55000
-
-static unsigned long model_static_power(struct kbase_ipa_model *model,
- unsigned long voltage)
-{
-#if LINUX_VERSION_CODE < KERNEL_VERSION(4, 3, 0)
- unsigned long temperature;
-#else
- int temperature;
-#endif
- unsigned long temp;
- unsigned long temp_squared, temp_cubed, temp_scaling_factor;
- const unsigned long voltage_cubed = (voltage * voltage * voltage) >> 10;
- struct kbase_ipa_model_generic_data *model_data =
- (struct kbase_ipa_model_generic_data *) model->model_data;
- struct thermal_zone_device *gpu_tz = model_data->gpu_tz;
-
- if (gpu_tz) {
- int ret;
-
- ret = gpu_tz->ops->get_temp(gpu_tz, &temperature);
- if (ret) {
- pr_warn_ratelimited("Error reading temperature for gpu thermal zone: %d\n",
- ret);
- temperature = FALLBACK_STATIC_TEMPERATURE;
- }
- } else {
- temperature = FALLBACK_STATIC_TEMPERATURE;
- }
-
- /* Calculate the temperature scaling factor. To be applied to the
- * voltage scaled power.
- */
- temp = temperature / 1000;
- temp_squared = temp * temp;
- temp_cubed = temp_squared * temp;
- temp_scaling_factor =
- (model_data->ts[3] * temp_cubed)
- + (model_data->ts[2] * temp_squared)
- + (model_data->ts[1] * temp)
- + model_data->ts[0];
-
- return (((model_data->static_coefficient * voltage_cubed) >> 20)
- * temp_scaling_factor)
- / 1000000;
-}
-
-static unsigned long model_dynamic_power(struct kbase_ipa_model *model)
-{
- struct kbase_ipa_model_generic_data *model_data =
- (struct kbase_ipa_model_generic_data *) model->model_data;
-
- return model_data->dynamic_coefficient;
-}
-
-static int kbase_generic_power_model_init(struct kbase_ipa_model *model)
-{
- struct kbase_device *kbdev = model->kbdev;
- struct device_node *power_model_node;
- const char *tz_name;
- u32 static_power, dynamic_power;
- u32 voltage, voltage_squared, voltage_cubed, frequency;
- struct kbase_ipa_model_generic_data *model_data;
- int err;
-
- model_data = kzalloc(sizeof(struct kbase_ipa_model_generic_data),
- GFP_KERNEL);
-
- if (!model_data)
- return -ENOMEM;
-
- power_model_node = of_get_child_by_name(kbdev->dev->of_node,
- "power_model");
- if (!power_model_node) {
- dev_err(kbdev->dev, "could not find power_model node\n");
- err = -ENODEV;
- goto error;
- }
- if (!of_device_is_compatible(power_model_node,
- "arm,mali-simple-power-model")) {
- dev_err(kbdev->dev, "power_model incompatible with simple power model\n");
- err = -ENODEV;
- goto error;
- }
-
- err = of_property_read_string(power_model_node, "thermal-zone",
- &tz_name);
- if (err) {
- dev_err(kbdev->dev, "thermal zone in power_model not available\n");
- goto error;
- }
-
- model_data->gpu_tz = thermal_zone_get_zone_by_name(tz_name);
- if (IS_ERR(model_data->gpu_tz)) {
- pr_warn_ratelimited("Error getting gpu thermal zone (%ld), not yet ready?\n",
- PTR_ERR(model_data->gpu_tz));
- model_data->gpu_tz = NULL;
- err = -EPROBE_DEFER;
- goto error;
- }
-
- err = of_property_read_u32(power_model_node, "static-power",
- &static_power);
- if (err) {
- dev_err(kbdev->dev, "static-power in power_model not available\n");
- goto error;
- }
-
- err = of_property_read_u32(power_model_node, "dynamic-power",
- &dynamic_power);
- if (err) {
- dev_err(kbdev->dev, "dynamic-power in power_model not available\n");
- goto error;
- }
-
- err = of_property_read_u32(power_model_node, "voltage",
- &voltage);
- if (err) {
- dev_err(kbdev->dev, "voltage in power_model not available\n");
- goto error;
- }
-
- err = of_property_read_u32(power_model_node, "frequency",
- &frequency);
- if (err) {
- dev_err(kbdev->dev, "frequency in power_model not available\n");
- goto error;
- }
- voltage_squared = (voltage * voltage) / 1000;
- voltage_cubed = voltage * voltage * voltage;
- model_data->static_coefficient =
- (static_power << 20) / (voltage_cubed >> 10);
- model_data->dynamic_coefficient =
- (((dynamic_power * 1000) / voltage_squared) * 1000) / frequency;
-
- err = of_property_read_u32_array(power_model_node,
- "ts",
- (u32 *)model_data->ts,
- 4);
- if (err) {
- dev_err(kbdev->dev, "ts in power_model not available\n");
- goto error;
- }
-
- model->model_data = (void *) model_data;
-
- return 0;
-error:
- kfree(model_data);
- return err;
-}
-
-static void kbase_generic_power_model_term(struct kbase_ipa_model *model)
-{
- struct kbase_ipa_model_generic_data *model_data =
- (struct kbase_ipa_model_generic_data *)model->model_data;
-
- kfree(model_data);
-}
-
-struct kbase_ipa_model_ops kbase_generic_ipa_model_ops = {
- .name = "generic_ipa_model",
- .init = &kbase_generic_power_model_init,
- .term = &kbase_generic_power_model_term,
- .get_dynamic_power = &model_dynamic_power,
- .get_static_power = &model_static_power,
- .power_to_state = NULL
-};