Lines Matching refs:rpmhpd
17 #include <dt-bindings/power/qcom,rpmhpd.h>
19 #define domain_to_rpmhpd(domain) container_of(domain, struct rpmhpd, pd)
24 * struct rpmhpd - top level RPMh power domain resource data structure
42 * @state_synced: Indicator that sync_state has been invoked for the rpmhpd resource
44 struct rpmhpd {
48 struct rpmhpd *peer;
62 struct rpmhpd **rpmhpds;
70 static struct rpmhpd cx_ao;
71 static struct rpmhpd mx;
72 static struct rpmhpd mx_ao;
73 static struct rpmhpd cx = {
79 static struct rpmhpd cx_ao = {
86 static struct rpmhpd cx_ao_w_mx_parent;
87 static struct rpmhpd cx_w_mx_parent = {
94 static struct rpmhpd cx_ao_w_mx_parent = {
102 static struct rpmhpd ebi = {
107 static struct rpmhpd gfx = {
112 static struct rpmhpd lcx = {
117 static struct rpmhpd lmx = {
122 static struct rpmhpd mmcx_ao;
123 static struct rpmhpd mmcx = {
129 static struct rpmhpd mmcx_ao = {
136 static struct rpmhpd mmcx_ao_w_cx_parent;
137 static struct rpmhpd mmcx_w_cx_parent = {
144 static struct rpmhpd mmcx_ao_w_cx_parent = {
152 static struct rpmhpd mss = {
157 static struct rpmhpd mx_ao;
158 static struct rpmhpd mx = {
164 static struct rpmhpd mx_ao = {
171 static struct rpmhpd mxc_ao;
172 static struct rpmhpd mxc = {
178 static struct rpmhpd mxc_ao = {
185 static struct rpmhpd nsp = {
190 static struct rpmhpd nsp0 = {
195 static struct rpmhpd nsp1 = {
200 static struct rpmhpd qphy = {
206 static struct rpmhpd *sa8540p_rpmhpds[] = {
225 static struct rpmhpd *sa8775p_rpmhpds[] = {
248 static struct rpmhpd *sdm670_rpmhpds[] = {
265 static struct rpmhpd *sdm845_rpmhpds[] = {
283 static struct rpmhpd *sdx55_rpmhpds[] = {
295 static struct rpmhpd *sdx65_rpmhpds[] = {
310 static struct rpmhpd *sdx75_rpmhpds[] = {
325 static struct rpmhpd *sm6350_rpmhpds[] = {
340 static struct rpmhpd *sm8150_rpmhpds[] = {
359 static struct rpmhpd *sa8155p_rpmhpds[] = {
375 static struct rpmhpd *sm8250_rpmhpds[] = {
394 static struct rpmhpd *sm8350_rpmhpds[] = {
416 static struct rpmhpd *sm8450_rpmhpds[] = {
438 static struct rpmhpd *sm8550_rpmhpds[] = {
461 static struct rpmhpd *qdu1000_rpmhpds[] = {
474 static struct rpmhpd *sc7180_rpmhpds[] = {
491 static struct rpmhpd *sc7280_rpmhpds[] = {
509 static struct rpmhpd *sc8180x_rpmhpds[] = {
529 static struct rpmhpd *sc8280xp_rpmhpds[] = {
550 { .compatible = "qcom,qdu1000-rpmhpd", .data = &qdu1000_desc },
551 { .compatible = "qcom,sa8155p-rpmhpd", .data = &sa8155p_desc },
552 { .compatible = "qcom,sa8540p-rpmhpd", .data = &sa8540p_desc },
553 { .compatible = "qcom,sa8775p-rpmhpd", .data = &sa8775p_desc },
554 { .compatible = "qcom,sc7180-rpmhpd", .data = &sc7180_desc },
555 { .compatible = "qcom,sc7280-rpmhpd", .data = &sc7280_desc },
556 { .compatible = "qcom,sc8180x-rpmhpd", .data = &sc8180x_desc },
557 { .compatible = "qcom,sc8280xp-rpmhpd", .data = &sc8280xp_desc },
558 { .compatible = "qcom,sdm670-rpmhpd", .data = &sdm670_desc },
559 { .compatible = "qcom,sdm845-rpmhpd", .data = &sdm845_desc },
560 { .compatible = "qcom,sdx55-rpmhpd", .data = &sdx55_desc},
561 { .compatible = "qcom,sdx65-rpmhpd", .data = &sdx65_desc},
562 { .compatible = "qcom,sdx75-rpmhpd", .data = &sdx75_desc},
563 { .compatible = "qcom,sm6350-rpmhpd", .data = &sm6350_desc },
564 { .compatible = "qcom,sm8150-rpmhpd", .data = &sm8150_desc },
565 { .compatible = "qcom,sm8250-rpmhpd", .data = &sm8250_desc },
566 { .compatible = "qcom,sm8350-rpmhpd", .data = &sm8350_desc },
567 { .compatible = "qcom,sm8450-rpmhpd", .data = &sm8450_desc },
568 { .compatible = "qcom,sm8550-rpmhpd", .data = &sm8550_desc },
573 static int rpmhpd_send_corner(struct rpmhpd *pd, int state,
591 static void to_active_sleep(struct rpmhpd *pd, unsigned int corner,
611 static int rpmhpd_aggregate_corner(struct rpmhpd *pd, unsigned int corner)
614 struct rpmhpd *peer = pd->peer;
662 struct rpmhpd *pd = domain_to_rpmhpd(domain);
680 struct rpmhpd *pd = domain_to_rpmhpd(domain);
697 struct rpmhpd *pd = domain_to_rpmhpd(domain);
736 static int rpmhpd_update_level_mapping(struct rpmhpd *rpmhpd)
741 buf = cmd_db_read_aux_data(rpmhpd->res_name, &rpmhpd->level_count);
746 rpmhpd->level_count >>= 1;
748 if (rpmhpd->level_count > RPMH_ARC_MAX_LEVELS)
751 for (i = 0; i < rpmhpd->level_count; i++) {
752 rpmhpd->level[i] = buf[i];
755 if (!rpmhpd->level[rpmhpd->enable_corner] && rpmhpd->level[i])
756 rpmhpd->enable_corner = i;
762 if (i > 0 && rpmhpd->level[i] == 0) {
763 rpmhpd->level_count = i;
766 pr_debug("%s: ARC hlvl=%2d --> vlvl=%4u\n", rpmhpd->res_name, i,
767 rpmhpd->level[i]);
779 struct rpmhpd **rpmhpds;
846 struct rpmhpd **rpmhpds = desc->rpmhpds;
848 struct rpmhpd *pd;
873 .name = "qcom-rpmhpd",