Lines Matching full:pd
19 #define domain_to_rpmhpd(domain) container_of(domain, struct rpmhpd, pd)
26 * @pd: generic_pm_domain corresponding to the power domain
47 struct generic_pm_domain pd; member
76 .pd = { .name = "cx", },
82 .pd = { .name = "cx_ao", },
90 .pd = { .name = "cx", },
92 .parent = &mx.pd,
97 .pd = { .name = "cx_ao", },
100 .parent = &mx_ao.pd,
105 .pd = { .name = "ebi", },
110 .pd = { .name = "gfx", },
115 .pd = { .name = "lcx", },
120 .pd = { .name = "lmx", },
126 .pd = { .name = "mmcx", },
132 .pd = { .name = "mmcx_ao", },
140 .pd = { .name = "mmcx", },
142 .parent = &cx.pd,
147 .pd = { .name = "mmcx_ao", },
150 .parent = &cx_ao.pd,
155 .pd = { .name = "mss", },
161 .pd = { .name = "mx", },
167 .pd = { .name = "mx_ao", },
175 .pd = { .name = "mxc", },
182 .pd = { .name = "mxc_ao", },
190 .pd = { .name = "nsp", },
195 .pd = { .name = "nsp0", },
200 .pd = { .name = "nsp1", },
205 .pd = { .name = "qphy", },
577 static int rpmhpd_send_corner(struct rpmhpd *pd, int state, in rpmhpd_send_corner() argument
581 .addr = pd->addr, in rpmhpd_send_corner()
590 return rpmh_write(pd->dev, state, &cmd, 1); in rpmhpd_send_corner()
592 return rpmh_write_async(pd->dev, state, &cmd, 1); in rpmhpd_send_corner()
595 static void to_active_sleep(struct rpmhpd *pd, unsigned int corner, in to_active_sleep() argument
600 if (pd->active_only) in to_active_sleep()
615 static int rpmhpd_aggregate_corner(struct rpmhpd *pd, unsigned int corner) in rpmhpd_aggregate_corner() argument
618 struct rpmhpd *peer = pd->peer; in rpmhpd_aggregate_corner()
624 if (pd->state_synced) { in rpmhpd_aggregate_corner()
625 to_active_sleep(pd, corner, &this_active_corner, &this_sleep_corner); in rpmhpd_aggregate_corner()
628 this_active_corner = pd->level_count - 1; in rpmhpd_aggregate_corner()
629 this_sleep_corner = pd->level_count - 1; in rpmhpd_aggregate_corner()
640 ret = rpmhpd_send_corner(pd, RPMH_ACTIVE_ONLY_STATE, active_corner, in rpmhpd_aggregate_corner()
641 active_corner > pd->active_corner); in rpmhpd_aggregate_corner()
645 pd->active_corner = active_corner; in rpmhpd_aggregate_corner()
650 ret = rpmhpd_send_corner(pd, RPMH_WAKE_ONLY_STATE, in rpmhpd_aggregate_corner()
657 return rpmhpd_send_corner(pd, RPMH_SLEEP_STATE, sleep_corner, in rpmhpd_aggregate_corner()
666 struct rpmhpd *pd = domain_to_rpmhpd(domain); in rpmhpd_power_on() local
672 corner = max(pd->corner, pd->enable_corner); in rpmhpd_power_on()
673 ret = rpmhpd_aggregate_corner(pd, corner); in rpmhpd_power_on()
675 pd->enabled = true; in rpmhpd_power_on()
684 struct rpmhpd *pd = domain_to_rpmhpd(domain); in rpmhpd_power_off() local
689 ret = rpmhpd_aggregate_corner(pd, 0); in rpmhpd_power_off()
691 pd->enabled = false; in rpmhpd_power_off()
701 struct rpmhpd *pd = domain_to_rpmhpd(domain); in rpmhpd_set_performance_state() local
706 for (i = 0; i < pd->level_count; i++) in rpmhpd_set_performance_state()
707 if (level <= pd->level[i]) in rpmhpd_set_performance_state()
714 if (i == pd->level_count) in rpmhpd_set_performance_state()
717 if (pd->enabled) { in rpmhpd_set_performance_state()
719 if (i < pd->enable_corner) in rpmhpd_set_performance_state()
720 i = pd->enable_corner; in rpmhpd_set_performance_state()
722 ret = rpmhpd_aggregate_corner(pd, i); in rpmhpd_set_performance_state()
727 pd->corner = i; in rpmhpd_set_performance_state()
829 rpmhpds[i]->pd.power_off = rpmhpd_power_off; in rpmhpd_probe()
830 rpmhpds[i]->pd.power_on = rpmhpd_power_on; in rpmhpd_probe()
831 rpmhpds[i]->pd.set_performance_state = rpmhpd_set_performance_state; in rpmhpd_probe()
832 rpmhpds[i]->pd.opp_to_performance_state = rpmhpd_get_performance_state; in rpmhpd_probe()
833 pm_genpd_init(&rpmhpds[i]->pd, NULL, true); in rpmhpd_probe()
835 data->domains[i] = &rpmhpds[i]->pd; in rpmhpd_probe()
844 &rpmhpds[i]->pd); in rpmhpd_probe()
855 struct rpmhpd *pd; in rpmhpd_sync_state() local
861 pd = rpmhpds[i]; in rpmhpd_sync_state()
862 if (!pd) in rpmhpd_sync_state()
865 pd->state_synced = true; in rpmhpd_sync_state()
866 if (pd->enabled) in rpmhpd_sync_state()
867 corner = max(pd->corner, pd->enable_corner); in rpmhpd_sync_state()
871 ret = rpmhpd_aggregate_corner(pd, corner); in rpmhpd_sync_state()
873 dev_err(dev, "failed to sync %s\n", pd->res_name); in rpmhpd_sync_state()