aboutsummaryrefslogtreecommitdiff
path: root/drivers/gpu/arm/midgard/mali_kbase_power_actor.h
blob: 5a0f1dc94100d23342f1e8e4e970d758df03fa32 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
/*
 *
 * (C) COPYRIGHT 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.
 *
 */




#ifndef _KBASE_POWER_ACTOR_H_
#define _KBASE_POWER_ACTOR_H_

#include <mali_kbase.h>

#include <linux/opp.h>

struct mali_pa_model_ops {
	unsigned long (*get_static_power)(unsigned long voltage, unsigned long temperature);
	unsigned long (*get_dynamic_power)(unsigned long freq);
};

struct mali_pa_power_table {
	unsigned long freq;
	unsigned long power;
};

struct mali_power_actor {
	struct kbase_device *kbdev;
	struct mali_pa_model_ops *ops;
	struct mali_pa_power_table *dyn_table;
	int dyn_table_count;
};

int mali_pa_init(struct kbase_device *kbdev);
void mali_pa_term(struct kbase_device *kbdev);


#endif