On 17 July 2014 01:26, Saravana Kannan <skannan@xxxxxxxxxxxxxx> wrote: > No it's not. All the cpu*/ directories for all possible CPUs will be there > whether a CPU is online/offline. Which is why I also weed out impossible > CPUs, but you said the driver shouldn't be passing impossible CPUs anyway. > I'm just picking one directory to put the real cpufreq directory under. So, > the code as-is is definitely not broken. I may be wrong, and that's why I checked it with Srivatsa. He is quite familiar with hotplug code. Let me show the example again, its a bit tricky. I agree with you that sysfs nodes for CPUs stay as is with offline events, but we aren't talking about that here. On boot when we are trying to bring CPUs online, some of them may fail to come. And in that case, as confirmed by Srivatsa, there are no sysfs directories. This doesn't happen normally and is a very corner case. Still think we are wrong? > Sure, I can pick the first cpu that comes online to decide where to put the > real sysfs cpufreq directory, but then I have to keep track of that in a > separate field when it's time to remove it when the cpufreq driver is > unregistered. It works this way right now and I don't think we maintain any separate field here. Subsys-interface takes care of the order in which CPUs are added/ removed. And we don't have to handle that here. Just fix policy->cpu at first cpufreq_add_dev(). > And no, we > shouldn't be moving sysfs directory to stay with only an online directory. > That's the thing this patch is trying to simplify. Ahh, I really missed it in reviews. So, that's why you are looking at first cpu of related_cpus.. Hmm, so it is quite possible that we would end up in a case where policy->cpu wouldn't have sysfs directory created for it. Not sure if that might cause some hickups. @Srivatsa: ?? > So, I think using the first cpu in related CPUs will always work. If there's > any disagreement, I think it's purely a personal preference over adding > another field vs calling cpumask_first() That's what the problem with this patch was, just too big to miss important things :) I now understood why you had these extra cpumask_first() calls. But having said that, I still don't see a need to change the current behavior. The important point is kobject and links are added just once, no movement. And so, I would still like to add it to policy->cpu, i.e. the cpu which comes first. And this happens only once while we register a driver, so no side effects probably. Not every platform is going through hotplug/suspend/resume and keeping policy->cpu and sysfs node aligned atleast for them might not be that bad. Though it will work for any cpu. -- To unsubscribe from this list: send the line "unsubscribe linux-arm-msm" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html