aboutsummaryrefslogtreecommitdiff
path: root/drivers/gpu/arm/t6xx/kbase/src/common/mali_kbase_hw.c
blob: b9e6a8a4594c2d8d0c9b4fc42b35200709d306d5 (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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
/*
 *
 * (C) COPYRIGHT 2012-2013 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.
 *
 */



/**
 * @file
 * Run-time work-arounds helpers
 */

#include <kbase/mali_base_hwconfig.h>
#include <kbase/src/common/mali_midg_regmap.h>
#include "mali_kbase.h"
#include "mali_kbase_hw.h"

mali_error kbase_hw_set_issues_mask(kbase_device *kbdev)
{
	const base_hw_issue *issues;
	u32 gpu_id;

	gpu_id = kbdev->gpu_props.props.raw_props.gpu_id;

	switch (gpu_id) {
	case GPU_ID_MAKE(GPU_ID_PI_T60X, 0, 0, GPU_ID_S_15DEV0):
		issues = base_hw_issues_t60x_r0p0_15dev0;
		break;
	case GPU_ID_MAKE(GPU_ID_PI_T60X, 0, 0, GPU_ID_S_EAC):
		issues = base_hw_issues_t60x_r0p0_eac;
		break;
	case GPU_ID_MAKE(GPU_ID_PI_T60X, 0, 1, 0):
		issues = base_hw_issues_t60x_r0p1;
		break;
	case GPU_ID_MAKE(GPU_ID_PI_T65X, 0, 1, 0):
		issues = base_hw_issues_t65x_r0p1;
		break;
	case GPU_ID_MAKE(GPU_ID_PI_T62X, 0, 0, 0):
	case GPU_ID_MAKE(GPU_ID_PI_T62X, 0, 0, 1):
		issues = base_hw_issues_t62x_r0p0;
		break;
	case GPU_ID_MAKE(GPU_ID_PI_T62X, 0, 1, 0):
		issues = base_hw_issues_t62x_r0p1;
		break;
	case GPU_ID_MAKE(GPU_ID_PI_T62X, 1, 0, 0):
	case GPU_ID_MAKE(GPU_ID_PI_T62X, 1, 0, 1):
		issues = base_hw_issues_t62x_r1p0;
 		break;
	case GPU_ID_MAKE(GPU_ID_PI_T67X, 0, 0, 0):
	case GPU_ID_MAKE(GPU_ID_PI_T67X, 0, 0, 1):
		issues = base_hw_issues_t67x_r0p0;
		break;
	case GPU_ID_MAKE(GPU_ID_PI_T67X, 0, 1, 0):
		issues = base_hw_issues_t67x_r0p1;
		break;
	case GPU_ID_MAKE(GPU_ID_PI_T67X, 1, 0, 0):
	case GPU_ID_MAKE(GPU_ID_PI_T67X, 1, 0, 1):
		issues = base_hw_issues_t67x_r1p0;
		break;
	case GPU_ID_MAKE(GPU_ID_PI_T75X, 0, 0, 0):
		issues = base_hw_issues_t75x_r0p0;
		break;
	default:
		KBASE_DEBUG_PRINT_ERROR(KBASE_CORE, "Unknown GPU ID %x", gpu_id);
		return MALI_ERROR_FUNCTION_FAILED;
	}

	KBASE_DEBUG_PRINT_INFO(KBASE_CORE, "GPU identified as 0x%04x r%dp%d status %d", (gpu_id & GPU_ID_VERSION_PRODUCT_ID) >> GPU_ID_VERSION_PRODUCT_ID_SHIFT, (gpu_id & GPU_ID_VERSION_MAJOR) >> GPU_ID_VERSION_MAJOR_SHIFT, (gpu_id & GPU_ID_VERSION_MINOR) >> GPU_ID_VERSION_MINOR_SHIFT, (gpu_id & GPU_ID_VERSION_STATUS) >> GPU_ID_VERSION_STATUS_SHIFT);

	for (; *issues != BASE_HW_ISSUE_END; issues++)
		set_bit(*issues, &kbdev->hw_issues_mask[0]);

	return MALI_ERROR_NONE;
}