Commit 16b26f60 authored by Wadim Egorov's avatar Wadim Egorov Committed by Alexandre Belloni

rtc: rv3028: Use IRQ flags obtained from device tree if available

Make the interrupt pin of the RV3028 usable with GPIO controllers
without level type IRQs support, such as the TI Davinci GPIO controller.

Therefore, allow the IRQ type to be passed from the device tree if
available.

Based on commit d4785b46 ("rtc: pcf2127: use IRQ flags obtained from device tree if available")
Signed-off-by: default avatarWadim Egorov <w.egorov@phytec.de>
Link: https://lore.kernel.org/r/20221208133605.4193907-1-w.egorov@phytec.deSigned-off-by: default avatarAlexandre Belloni <alexandre.belloni@bootlin.com>
parent 0feebdeb
...@@ -902,9 +902,20 @@ static int rv3028_probe(struct i2c_client *client) ...@@ -902,9 +902,20 @@ static int rv3028_probe(struct i2c_client *client)
return PTR_ERR(rv3028->rtc); return PTR_ERR(rv3028->rtc);
if (client->irq > 0) { if (client->irq > 0) {
unsigned long flags;
/*
* If flags = 0, devm_request_threaded_irq() will use IRQ flags
* obtained from device tree.
*/
if (dev_fwnode(&client->dev))
flags = 0;
else
flags = IRQF_TRIGGER_LOW;
ret = devm_request_threaded_irq(&client->dev, client->irq, ret = devm_request_threaded_irq(&client->dev, client->irq,
NULL, rv3028_handle_irq, NULL, rv3028_handle_irq,
IRQF_TRIGGER_LOW | IRQF_ONESHOT, flags | IRQF_ONESHOT,
"rv3028", rv3028); "rv3028", rv3028);
if (ret) { if (ret) {
dev_warn(&client->dev, "unable to request IRQ, alarms disabled\n"); dev_warn(&client->dev, "unable to request IRQ, alarms disabled\n");
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment