hc
2023-12-09 b22da3d8526a935aa31e086e63f60ff3246cb61c
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
85
86
87
88
89
// SPDX-License-Identifier: GPL-2.0-only
/*
 * OMAP5 Voltage Management Routines
 *
 * Based on voltagedomains44xx_data.c
 *
 * Copyright (C) 2013 Texas Instruments Incorporated - https://www.ti.com
 */
#include <linux/kernel.h>
#include <linux/err.h>
#include <linux/init.h>
 
#include "common.h"
 
#include "prm54xx.h"
#include "voltage.h"
#include "omap_opp_data.h"
#include "vc.h"
#include "vp.h"
 
static const struct omap_vfsm_instance omap5_vdd_mpu_vfsm = {
   .voltsetup_reg = OMAP54XX_PRM_VOLTSETUP_MPU_RET_SLEEP_OFFSET,
};
 
static const struct omap_vfsm_instance omap5_vdd_mm_vfsm = {
   .voltsetup_reg = OMAP54XX_PRM_VOLTSETUP_MM_RET_SLEEP_OFFSET,
};
 
static const struct omap_vfsm_instance omap5_vdd_core_vfsm = {
   .voltsetup_reg = OMAP54XX_PRM_VOLTSETUP_CORE_RET_SLEEP_OFFSET,
};
 
static struct voltagedomain omap5_voltdm_mpu = {
   .name = "mpu",
   .scalable = true,
   .read = omap4_prm_vcvp_read,
   .write = omap4_prm_vcvp_write,
   .rmw = omap4_prm_vcvp_rmw,
   .vc = &omap4_vc_mpu,
   .vfsm = &omap5_vdd_mpu_vfsm,
   .vp = &omap4_vp_mpu,
};
 
static struct voltagedomain omap5_voltdm_mm = {
   .name = "mm",
   .scalable = true,
   .read = omap4_prm_vcvp_read,
   .write = omap4_prm_vcvp_write,
   .rmw = omap4_prm_vcvp_rmw,
   .vc = &omap4_vc_iva,
   .vfsm = &omap5_vdd_mm_vfsm,
   .vp = &omap4_vp_iva,
};
 
static struct voltagedomain omap5_voltdm_core = {
   .name = "core",
   .scalable = true,
   .read = omap4_prm_vcvp_read,
   .write = omap4_prm_vcvp_write,
   .rmw = omap4_prm_vcvp_rmw,
   .vc = &omap4_vc_core,
   .vfsm = &omap5_vdd_core_vfsm,
   .vp = &omap4_vp_core,
};
 
static struct voltagedomain omap5_voltdm_wkup = {
   .name = "wkup",
};
 
static struct voltagedomain *voltagedomains_omap5[] __initdata = {
   &omap5_voltdm_mpu,
   &omap5_voltdm_mm,
   &omap5_voltdm_core,
   &omap5_voltdm_wkup,
   NULL,
};
 
static const char *const sys_clk_name __initconst = "sys_clkin";
 
void __init omap54xx_voltagedomains_init(void)
{
   struct voltagedomain *voltdm;
   int i;
 
   for (i = 0; voltdm = voltagedomains_omap5[i], voltdm; i++)
       voltdm->sys_clk.name = sys_clk_name;
 
   voltdm_init(voltagedomains_omap5);
};