>+ */ >+int set_latency(struct shared_resource *resp, u32 latency) >+{ >+ u8 *pm_qos_req_added; >+ >+ if (resp->curr_level == latency) >+ return 0; >+ else >+ /* Update the resources current level */ >+ resp->curr_level = latency; >+ [Romit] I think this should be done outside this function, in update_resource_level function. >+ pm_qos_req_added = resp->resource_data; >+ if (latency == RES_DEFAULTLEVEL) >+ /* No more users left, remove the pm_qos_req if present */ >+ if (*pm_qos_req_added) { >+ > pm_qos_remove_requirement(PM_QOS_CPU_DMA_LATENCY, >+ resp->name); >+ *pm_qos_req_added = 0; >+ return 0; >+ } >+ >+ if (*pm_qos_req_added) { >+ return >pm_qos_update_requirement(PM_QOS_CPU_DMA_LATENCY, >+ resp->name, latency); >+ } else { [Romit] Shouldn't the following line execute only if pm_qos_add_requirement returns successfully? >+ *pm_qos_req_added = 1; >+ return pm_qos_add_requirement(PM_QOS_CPU_DMA_LATENCY, >+ resp->name, latency); >+ } >+} >+ >+int set_pd_latency(struct shared_resource *resp, u32 latency) >+{ >+ u32 pd_lat_level, ind; >+ struct pd_latency_db *pd_lat_db; >+ struct powerdomain *pwrdm; >+ >+ pd_lat_db = resp->resource_data; >+ pwrdm = pd_lat_db->pd; >+ pd_lat_level = PD_LATENCY_OFF; >+ /* using the latency db map to the appropriate PD state */ >+ for (ind = 0; ind < PD_LATENCY_MAXLEVEL; ind++) { >+ if (pd_lat_db->latency[ind] < latency) { >+ pd_lat_level = ind; >+ break; >+ } >+ } >+ [Romit] Again is this the right place for this? It should be done only if set_pwrdm_state returns successfully. So I think that should be checked as well. >+ resp->curr_level = pd_lat_level; >+ set_pwrdm_state(pwrdm, pd_lat_level); >+ return 0; >+} -- To unsubscribe from this list: send the line "unsubscribe linux-omap" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html