blob: 2683adf45e61134775723a8b850b0d9a3aff2173 (
plain) (
blame)
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
|
#include <asm/io.h>
#include <linux/string.h>
#include "smi_reg.h"
#include <mach/mt_smi.h>
#include "smi_common.h"
#include "smi_configuration.h"
#include "smi_config_util.h"
int smi_bus_regs_setting(int profile, struct SMI_SETTING *settings)
{
int i = 0;
int j = 0;
if (!settings || profile < 0 || profile >= SMI_BWC_SCEN_CNT)
return -1;
if (settings->smi_common_reg_num == 0)
return -1;
/* set regs of common */
SMIMSG("Current Scen:%d", profile);
for (i = 0 ; i < settings->smi_common_reg_num ; ++i) {
M4U_WriteReg32(SMI_COMMON_EXT_BASE,
settings->smi_common_setting_vals[i].offset,
settings->smi_common_setting_vals[i].value);
}
/* set regs of larbs */
for (i = 0 ; i < SMI_LARB_NR ; ++i)
for (j = 0 ; j < settings->smi_larb_reg_num[i] ; ++j) {
M4U_WriteReg32(gLarbBaseAddr[i],
settings->smi_larb_setting_vals[i][j].offset,
settings->smi_larb_setting_vals[i][j].value);
}
return 0;
}
void save_default_common_val(int *is_default_value_saved, unsigned int *default_val_smi_array)
{
if (!*is_default_value_saved) {
int i = 0;
SMIMSG("Save default config:\n");
for (i = 0 ; i < SMI_LARB_NR ; ++i)
default_val_smi_array[i] = M4U_ReadReg32(SMI_COMMON_EXT_BASE, smi_common_l1arb_offset[i]);
*is_default_value_saved = 1;
}
}
|