Merge branches 'irq-urgent-for-linus' and 'irq-core-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip
Pull irq update from Thomas Gleixner: "Fix from the urgent branch: a trivial oneliner adding the missing Kconfig dependency curing build failures which have been discovered by several build robots. The update in the irq-core branch provides a new function in the irq/devres code, which is a prerequisite for driver developers to get rid of boilerplate code all over the place. Not a bugfix, but it has zero impact on the current kernel due to the lack of users. It's simpler to provide the infrastructure to interested parties via your tree than fulfilling the wishlist of driver maintainers on which particular commit or tag this should be based on" * 'irq-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: genirq: Add missing irq_to_desc export for CONFIG_SPARSE_IRQ=n * 'irq-core-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: genirq: Add devm_request_any_context_irq()
This commit is contained in:
commit
5a667a0c02
|
@ -158,6 +158,11 @@ devm_request_irq(struct device *dev, unsigned int irq, irq_handler_t handler,
|
||||||
devname, dev_id);
|
devname, dev_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
extern int __must_check
|
||||||
|
devm_request_any_context_irq(struct device *dev, unsigned int irq,
|
||||||
|
irq_handler_t handler, unsigned long irqflags,
|
||||||
|
const char *devname, void *dev_id);
|
||||||
|
|
||||||
extern void devm_free_irq(struct device *dev, unsigned int irq, void *dev_id);
|
extern void devm_free_irq(struct device *dev, unsigned int irq, void *dev_id);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -72,6 +72,51 @@ int devm_request_threaded_irq(struct device *dev, unsigned int irq,
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(devm_request_threaded_irq);
|
EXPORT_SYMBOL(devm_request_threaded_irq);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* devm_request_any_context_irq - allocate an interrupt line for a managed device
|
||||||
|
* @dev: device to request interrupt for
|
||||||
|
* @irq: Interrupt line to allocate
|
||||||
|
* @handler: Function to be called when the IRQ occurs
|
||||||
|
* @thread_fn: function to be called in a threaded interrupt context. NULL
|
||||||
|
* for devices which handle everything in @handler
|
||||||
|
* @irqflags: Interrupt type flags
|
||||||
|
* @devname: An ascii name for the claiming device
|
||||||
|
* @dev_id: A cookie passed back to the handler function
|
||||||
|
*
|
||||||
|
* Except for the extra @dev argument, this function takes the
|
||||||
|
* same arguments and performs the same function as
|
||||||
|
* request_any_context_irq(). IRQs requested with this function will be
|
||||||
|
* automatically freed on driver detach.
|
||||||
|
*
|
||||||
|
* If an IRQ allocated with this function needs to be freed
|
||||||
|
* separately, devm_free_irq() must be used.
|
||||||
|
*/
|
||||||
|
int devm_request_any_context_irq(struct device *dev, unsigned int irq,
|
||||||
|
irq_handler_t handler, unsigned long irqflags,
|
||||||
|
const char *devname, void *dev_id)
|
||||||
|
{
|
||||||
|
struct irq_devres *dr;
|
||||||
|
int rc;
|
||||||
|
|
||||||
|
dr = devres_alloc(devm_irq_release, sizeof(struct irq_devres),
|
||||||
|
GFP_KERNEL);
|
||||||
|
if (!dr)
|
||||||
|
return -ENOMEM;
|
||||||
|
|
||||||
|
rc = request_any_context_irq(irq, handler, irqflags, devname, dev_id);
|
||||||
|
if (rc) {
|
||||||
|
devres_free(dr);
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
|
dr->irq = irq;
|
||||||
|
dr->dev_id = dev_id;
|
||||||
|
devres_add(dev, dr);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL(devm_request_any_context_irq);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* devm_free_irq - free an interrupt
|
* devm_free_irq - free an interrupt
|
||||||
* @dev: device to free interrupt for
|
* @dev: device to free interrupt for
|
||||||
|
|
|
@ -274,6 +274,7 @@ struct irq_desc *irq_to_desc(unsigned int irq)
|
||||||
{
|
{
|
||||||
return (irq < NR_IRQS) ? irq_desc + irq : NULL;
|
return (irq < NR_IRQS) ? irq_desc + irq : NULL;
|
||||||
}
|
}
|
||||||
|
EXPORT_SYMBOL(irq_to_desc);
|
||||||
|
|
||||||
static void free_desc(unsigned int irq)
|
static void free_desc(unsigned int irq)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue