import PULS_20160108
[GitHub/mt8127/android_kernel_alcatel_ttab.git] / drivers / misc / mediatek / gpu / mt8127 / mali / mali / common / mali_scheduler.c
1 /*
2 * This confidential and proprietary software may be used only as
3 * authorised by a licensing agreement from ARM Limited
4 * (C) COPYRIGHT 2012-2013 ARM Limited
5 * ALL RIGHTS RESERVED
6 * The entire notice above must be reproduced on all authorised
7 * copies and copies may only be made to the extent permitted
8 * by a licensing agreement from ARM Limited.
9 */
10
11 #include "mali_scheduler.h"
12
13 #include "mali_kernel_common.h"
14 #include "mali_osk.h"
15
16 mali_bool mali_scheduler_hints[MALI_SCHEDULER_HINT_MAX];
17
18 static _mali_osk_atomic_t mali_job_id_autonumber;
19 static _mali_osk_atomic_t mali_job_cache_order_autonumber;
20
21 static _mali_osk_wq_work_t *pp_scheduler_wq_high_pri = NULL;
22 static _mali_osk_wq_work_t *gp_scheduler_wq_high_pri = NULL;
23
24 static void mali_scheduler_wq_schedule_pp(void *arg)
25 {
26 MALI_IGNORE(arg);
27
28 mali_pp_scheduler_schedule();
29 }
30
31 static void mali_scheduler_wq_schedule_gp(void *arg)
32 {
33 MALI_IGNORE(arg);
34
35 mali_gp_scheduler_schedule();
36 }
37
38 _mali_osk_errcode_t mali_scheduler_initialize(void)
39 {
40 if ( _MALI_OSK_ERR_OK != _mali_osk_atomic_init(&mali_job_id_autonumber, 0)) {
41 MALI_DEBUG_PRINT(1, ("Initialization of atomic job id counter failed.\n"));
42 return _MALI_OSK_ERR_FAULT;
43 }
44
45 if ( _MALI_OSK_ERR_OK != _mali_osk_atomic_init(&mali_job_cache_order_autonumber, 0)) {
46 MALI_DEBUG_PRINT(1, ("Initialization of atomic job cache order counter failed.\n"));
47 _mali_osk_atomic_term(&mali_job_id_autonumber);
48 return _MALI_OSK_ERR_FAULT;
49 }
50
51 pp_scheduler_wq_high_pri = _mali_osk_wq_create_work_high_pri(mali_scheduler_wq_schedule_pp, NULL);
52 if (NULL == pp_scheduler_wq_high_pri) {
53 _mali_osk_atomic_term(&mali_job_cache_order_autonumber);
54 _mali_osk_atomic_term(&mali_job_id_autonumber);
55 return _MALI_OSK_ERR_NOMEM;
56 }
57
58 gp_scheduler_wq_high_pri = _mali_osk_wq_create_work_high_pri(mali_scheduler_wq_schedule_gp, NULL);
59 if (NULL == gp_scheduler_wq_high_pri) {
60 _mali_osk_wq_delete_work(pp_scheduler_wq_high_pri);
61 _mali_osk_atomic_term(&mali_job_cache_order_autonumber);
62 _mali_osk_atomic_term(&mali_job_id_autonumber);
63 return _MALI_OSK_ERR_NOMEM;
64 }
65
66 return _MALI_OSK_ERR_OK;
67 }
68
69 void mali_scheduler_terminate(void)
70 {
71 _mali_osk_wq_delete_work(gp_scheduler_wq_high_pri);
72 _mali_osk_wq_delete_work(pp_scheduler_wq_high_pri);
73 _mali_osk_atomic_term(&mali_job_cache_order_autonumber);
74 _mali_osk_atomic_term(&mali_job_id_autonumber);
75 }
76
77 u32 mali_scheduler_get_new_id(void)
78 {
79 u32 job_id = _mali_osk_atomic_inc_return(&mali_job_id_autonumber);
80 return job_id;
81 }
82
83 u32 mali_scheduler_get_new_cache_order(void)
84 {
85 u32 job_cache_order = _mali_osk_atomic_inc_return(&mali_job_cache_order_autonumber);
86 return job_cache_order;
87 }
88
89 void mali_scheduler_schedule_from_mask(mali_scheduler_mask mask, mali_bool deferred_schedule)
90 {
91 if (MALI_SCHEDULER_MASK_GP & mask) {
92 /* GP needs scheduling. */
93 if (deferred_schedule) {
94 /* Schedule GP deferred. */
95 _mali_osk_wq_schedule_work_high_pri(gp_scheduler_wq_high_pri);
96 } else {
97 /* Schedule GP now. */
98 mali_gp_scheduler_schedule();
99 }
100 }
101
102 if (MALI_SCHEDULER_MASK_PP & mask) {
103 /* PP needs scheduling. */
104 if (deferred_schedule) {
105 /* Schedule PP deferred. */
106 _mali_osk_wq_schedule_work_high_pri(pp_scheduler_wq_high_pri);
107 } else {
108 /* Schedule PP now. */
109 mali_pp_scheduler_schedule();
110 }
111 }
112 }