From: Chanwoo Choi Date: Thu, 14 Apr 2016 05:37:12 +0000 (+0900) Subject: PM / devfreq: event: Find the instance of devfreq-event device by using phandle X-Git-Url: https://git.stricted.de/?a=commitdiff_plain;h=19cf91d0f9ddc494217a0abaed91dfbddea7c958;p=GitHub%2FLineageOS%2Fandroid_kernel_motorola_exynos9610.git PM / devfreq: event: Find the instance of devfreq-event device by using phandle This patch use the phandle to find the instance of devfreq-event device in Device Tree when calling the devfreq_event_get_edev_by_phandle() because there is two type devfreq-event devices as following: First case, exynos-ppmu.c driver provides the maximum four event of each PPMU. So, when getting the instance of devfreq-event device, using the unique name of struct devfreq_event_desc. Second case, exynos-nocp.c driver provide the only one event of each NoC Probe device. So, when getting the instance of devfreq-event device, using the phandle of each NoC probe device. Signed-off-by: Chanwoo Choi Acked-by: MyungJoo Ham --- diff --git a/drivers/devfreq/devfreq-event.c b/drivers/devfreq/devfreq-event.c index 38bf144ca147..39b048eda2ce 100644 --- a/drivers/devfreq/devfreq-event.c +++ b/drivers/devfreq/devfreq-event.c @@ -234,6 +234,11 @@ struct devfreq_event_dev *devfreq_event_get_edev_by_phandle(struct device *dev, return ERR_PTR(-ENODEV); mutex_lock(&devfreq_event_list_lock); + list_for_each_entry(edev, &devfreq_event_list, node) { + if (edev->dev.parent && edev->dev.parent->of_node == node) + goto out; + } + list_for_each_entry(edev, &devfreq_event_list, node) { if (!strcmp(edev->desc->name, node->name)) goto out;