mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-09-18 22:14:16 +00:00
regulator: irq_helper: Provide helper for trivial IRQ notifications
Provide a generic map_event helper for regulators which have a notification IRQ with single, well defined purpose. Eg, IRQ always indicates exactly one event for exactly one regulator device. For such IRQs the mapping is trivial. Signed-off-by: Matti Vaittinen <matti.vaittinen@fi.rohmeurope.com> Link: https://lore.kernel.org/r/603b7ed1938013a00371c1e7ccc63dfb16982b87.1637736436.git.matti.vaittinen@fi.rohmeurope.com Signed-off-by: Mark Brown <broonie@kernel.org>
This commit is contained in:
parent
6fadec4c55
commit
a764ff77d6
2 changed files with 42 additions and 1 deletions
|
@ -320,7 +320,9 @@ static void init_rdev_errors(struct regulator_irq *h)
|
||||||
* IRQF_ONESHOT when requesting the (threaded) irq.
|
* IRQF_ONESHOT when requesting the (threaded) irq.
|
||||||
* @common_errs: Errors which can be flagged by this IRQ for all rdevs.
|
* @common_errs: Errors which can be flagged by this IRQ for all rdevs.
|
||||||
* When IRQ is re-enabled these errors will be cleared
|
* When IRQ is re-enabled these errors will be cleared
|
||||||
* from all associated regulators
|
* from all associated regulators. Use this instead of the
|
||||||
|
* per_rdev_errs if you use
|
||||||
|
* regulator_irq_map_event_simple() for event mapping.
|
||||||
* @per_rdev_errs: Optional error flag array describing errors specific
|
* @per_rdev_errs: Optional error flag array describing errors specific
|
||||||
* for only some of the regulators. These errors will be
|
* for only some of the regulators. These errors will be
|
||||||
* or'ed with common errors. If this is given the array
|
* or'ed with common errors. If this is given the array
|
||||||
|
@ -395,3 +397,40 @@ void regulator_irq_helper_cancel(void **handle)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(regulator_irq_helper_cancel);
|
EXPORT_SYMBOL_GPL(regulator_irq_helper_cancel);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* regulator_irq_map_event_simple - regulator IRQ notification for trivial IRQs
|
||||||
|
*
|
||||||
|
* @irq: Number of IRQ that occurred
|
||||||
|
* @rid: Information about the event IRQ indicates
|
||||||
|
* @dev_mask: mask indicating the regulator originating the IRQ
|
||||||
|
*
|
||||||
|
* Regulators whose IRQ has single, well defined purpose (always indicate
|
||||||
|
* exactly one event, and are relevant to exactly one regulator device) can
|
||||||
|
* use this function as their map_event callbac for their regulator IRQ
|
||||||
|
* notification helperk. Exactly one rdev and exactly one error (in
|
||||||
|
* "common_errs"-field) can be given at IRQ helper registration for
|
||||||
|
* regulator_irq_map_event_simple() to be viable.
|
||||||
|
*/
|
||||||
|
int regulator_irq_map_event_simple(int irq, struct regulator_irq_data *rid,
|
||||||
|
unsigned long *dev_mask)
|
||||||
|
{
|
||||||
|
int err = rid->states[0].possible_errs;
|
||||||
|
|
||||||
|
*dev_mask = 1;
|
||||||
|
/*
|
||||||
|
* This helper should only be used in a situation where the IRQ
|
||||||
|
* can indicate only one type of problem for one specific rdev.
|
||||||
|
* Something fishy is going on if we are having multiple rdevs or ERROR
|
||||||
|
* flags here.
|
||||||
|
*/
|
||||||
|
if (WARN_ON(rid->num_states != 1 || hweight32(err) != 1))
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
rid->states[0].errors = err;
|
||||||
|
rid->states[0].notifs = regulator_err2notif(err);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(regulator_irq_map_event_simple);
|
||||||
|
|
||||||
|
|
|
@ -700,6 +700,8 @@ void *regulator_irq_helper(struct device *dev,
|
||||||
int irq_flags, int common_errs, int *per_rdev_errs,
|
int irq_flags, int common_errs, int *per_rdev_errs,
|
||||||
struct regulator_dev **rdev, int rdev_amount);
|
struct regulator_dev **rdev, int rdev_amount);
|
||||||
void regulator_irq_helper_cancel(void **handle);
|
void regulator_irq_helper_cancel(void **handle);
|
||||||
|
int regulator_irq_map_event_simple(int irq, struct regulator_irq_data *rid,
|
||||||
|
unsigned long *dev_mask);
|
||||||
|
|
||||||
void *rdev_get_drvdata(struct regulator_dev *rdev);
|
void *rdev_get_drvdata(struct regulator_dev *rdev);
|
||||||
struct device *rdev_get_dev(struct regulator_dev *rdev);
|
struct device *rdev_get_dev(struct regulator_dev *rdev);
|
||||||
|
|
Loading…
Add table
Reference in a new issue