forked from Minki/linux
298ff0122a
Current in-tree users of ISL12057 RTC chip (NETGEAR ReadyNAS 102, 104 and 2120) do not have the IRQ#2 pin of the chip (associated w/ the Alarm1 mechanism) connected to their SoC, but to a PMIC (TPS65251 FWIW). This specific hardware configuration allows the NAS to wake up when the alarms rings. Recently introduced alarm support for ISL12057 relies on the provision of an "interrupts" property in system .dts file, which previous three users will never get. For that reason, alarm support on those devices is not function. To support this use case, this patch adds a new DT property for ISL12057 (isil,irq2-can-wakeup-machine) to indicate that the chip is capable of waking up the device using its IRQ#2 pin (even though it does not have its IRQ#2 pin connected directly to the SoC). This specific configuration was tested on a ReadyNAS 102 by setting an alarm, powering off the device and see it reboot as expected when the alarm rang w/: # echo `date '+%s' -d '+ 1 minutes'` > /sys/class/rtc/rtc0/wakealarm # shutdown -h now As a side note, the ISL12057 remains in the list of trivial devices, because the property is not per se required by the device to work but can help handle system w/ specific requirements. In exchange, the new feature is described in details in a specific documentation file. Signed-off-by: Arnaud Ebalard <arno@natisbad.org> Cc: Mark Rutland <mark.rutland@arm.com> Cc: Alessandro Zummo <a.zummo@towertech.it> Cc: Peter Huewe <peter.huewe@infineon.com> Cc: Linus Walleij <linus.walleij@linaro.org> Cc: Thierry Reding <treding@nvidia.com> Cc: Mark Brown <broonie@kernel.org> Cc: Arnd Bergmann <arnd@arndb.de> Cc: Darshana Padmadas <darshanapadmadas@gmail.com> Cc: Rob Herring <rob.herring@calxeda.com> Cc: Pawel Moll <pawel.moll@arm.com> Cc: Stephen Warren <swarren@wwwdotorg.org> Cc: Ian Campbell <ijc+devicetree@hellion.org.uk> Cc: Grant Likely <grant.likely@linaro.org> Cc: Rob Landley <rob@landley.net> Cc: Jason Cooper <jason@lakedaemon.net> Cc: Guenter Roeck <linux@roeck-us.net> Cc: Jason Gunthorpe <jgunthorpe@obsidianresearch.com> Cc: Kumar Gala <galak@codeaurora.org> Cc: Uwe Kleine-König <uwe@kleine-koenig.org> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
79 lines
2.3 KiB
Plaintext
79 lines
2.3 KiB
Plaintext
Intersil ISL12057 I2C RTC/Alarm chip
|
|
|
|
ISL12057 is a trivial I2C device (it has simple device tree bindings,
|
|
consisting of a compatible field, an address and possibly an interrupt
|
|
line).
|
|
|
|
Nonetheless, it also supports an option boolean property
|
|
("isil,irq2-can-wakeup-machine") to handle the specific use-case found
|
|
on at least three in-tree users of the chip (NETGEAR ReadyNAS 102, 104
|
|
and 2120 ARM-based NAS); On those devices, the IRQ#2 pin of the chip
|
|
(associated with the alarm supported by the driver) is not connected
|
|
to the SoC but to a PMIC. It allows the device to be powered up when
|
|
RTC alarm rings. In order to mark the device has a wakeup source and
|
|
get access to the 'wakealarm' sysfs entry, this specific property can
|
|
be set when the IRQ#2 pin of the chip is not connected to the SoC but
|
|
can wake up the device.
|
|
|
|
Required properties supported by the device:
|
|
|
|
- "compatible": must be "isil,isl12057"
|
|
- "reg": I2C bus address of the device
|
|
|
|
Optional properties:
|
|
|
|
- "isil,irq2-can-wakeup-machine": mark the chip as a wakeup source,
|
|
independently of the availability of an IRQ line connected to the
|
|
SoC.
|
|
|
|
- "interrupt-parent", "interrupts": for passing the interrupt line
|
|
of the SoC connected to IRQ#2 of the RTC chip.
|
|
|
|
|
|
Example isl12057 node without IRQ#2 pin connected (no alarm support):
|
|
|
|
isl12057: isl12057@68 {
|
|
compatible = "isil,isl12057";
|
|
reg = <0x68>;
|
|
};
|
|
|
|
|
|
Example isl12057 node with IRQ#2 pin connected to main SoC via MPP6 (note
|
|
that the pinctrl-related properties below are given for completeness and
|
|
may not be required or may be different depending on your system or
|
|
SoC, and the main function of the MPP used as IRQ line, i.e.
|
|
"interrupt-parent" and "interrupts" are usually sufficient):
|
|
|
|
pinctrl {
|
|
...
|
|
|
|
rtc_alarm_pin: rtc_alarm_pin {
|
|
marvell,pins = "mpp6";
|
|
marvell,function = "gpio";
|
|
};
|
|
|
|
...
|
|
|
|
};
|
|
|
|
...
|
|
|
|
isl12057: isl12057@68 {
|
|
compatible = "isil,isl12057";
|
|
reg = <0x68>;
|
|
pinctrl-0 = <&rtc_alarm_pin>;
|
|
pinctrl-names = "default";
|
|
interrupt-parent = <&gpio0>;
|
|
interrupts = <6 IRQ_TYPE_EDGE_FALLING>;
|
|
};
|
|
|
|
|
|
Example isl12057 node without IRQ#2 pin connected to the SoC but to a
|
|
PMIC, allowing the device to be started based on configured alarm:
|
|
|
|
isl12057: isl12057@68 {
|
|
compatible = "isil,isl12057";
|
|
reg = <0x68>;
|
|
isil,irq2-can-wakeup-machine;
|
|
};
|