On 2011년 09월 07일 00:46, Guenter Roeck wrote: > On Mon, 2011-09-05 at 05:41 -0400, Donggeun Kim wrote: >> This patch allows to read temperature >> from TMU(Thermal Management Unit) of SAMSUNG EXYNOS4 series of SoC. >> >> Signed-off-by: Donggeun Kim <dg77.kim@xxxxxxxxxxx> >> Signed-off-by: MyungJoo Ham <myungjoo.ham@xxxxxxxxxxx> >> Signed-off-by: Kyungmin Park <kyungmin.park@xxxxxxxxxxx> > [snip] >> + >> +static void exynos4_tmu_work(struct work_struct *work) >> +{ >> + struct exynos4_tmu_data *data = container_of(work, >> + struct exynos4_tmu_data, irq_work); >> + unsigned int interrupt_stat; >> + char *envp[2]; >> + >> + mutex_lock(&data->lock); >> + clk_enable(data->clk); >> + >> + interrupt_stat = readl(data->base + EXYNOS4_TMU_REG_INTSTAT); >> + >> + writel(EXYNOS4_TMU_INTCLEAR_VAL, data->base + EXYNOS4_TMU_REG_INTCLEAR); >> + >> + if (interrupt_stat & EXYNOS4_TMU_TRIG_LEVEL3_MASK) { >> + envp[0] = "TRIG_LEVEL=3"; >> + sysfs_notify(&data->hwmon_dev->kobj, NULL, >> + "temp1_emergency_alarm"); >> + } else if (interrupt_stat & EXYNOS4_TMU_TRIG_LEVEL2_MASK) { >> + envp[0] = "TRIG_LEVEL=2"; >> + sysfs_notify(&data->hwmon_dev->kobj, NULL, >> + "temp1_crit_alarm"); >> + } else if (interrupt_stat & EXYNOS4_TMU_TRIG_LEVEL1_MASK) { >> + envp[0] = "TRIG_LEVEL=1"; >> + sysfs_notify(&data->hwmon_dev->kobj, NULL, "temp1_max_alarm"); >> + } else >> + envp[0] = "TRIG_LEVEL=0"; >> + envp[1] = NULL; >> + >> + kobject_uevent_env(&data->hwmon_dev->kobj, KOBJ_CHANGE, envp); >> + > > Concern here is two-fold: envp is driver specific, and sysfs_notify() > should really be called whenever an attribute changes its state. Right > now it is only called for 0->1 transitions, but not for 1->0 > transitions, which means that any listener will not get notified for > 1->0 transitions. This makes the sysfs notification pretty much useless. > > For the uevent, I would suggest to generate the global uevent as other > drivers do it right now. > kobject_uevent(&data->hwmon_dev->kobj, KOBJ_CHANGE); > An alternative would be to pass one of the changed attribute names as > environment (eg the highest temperature 0->1 transition). > It would be okay to call 'kobject_uevent' function instead of 'kobject_uevent_env' function. > For the 1->0 transitions, I don't really have a good idea how to handle > it if the chip does not generate interrupts in this case. Not really > sure, though, if calling sysfs_notify even makes sense in that case, > since a poll on a "triggered" attribute file will be stuck forever. > I think the sysfs notification is not useful due to no support for 1->0 transitions. I will remove it in the next patch. [snip] Thanks. -- To unsubscribe from this list: send the line "unsubscribe linux-doc" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html