mirror of
				https://github.com/torvalds/linux.git
				synced 2025-11-04 10:40:15 +02:00 
			
		
		
		
	genirq/irqdomain: Add map counter
Add a map counter instead of counting radix tree entries for diagnosis. That also gives correct information for linear domains. Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Acked-by: Marc Zyngier <marc.zyngier@arm.com> Cc: Jens Axboe <axboe@kernel.dk> Cc: Michael Ellerman <mpe@ellerman.id.au> Cc: Keith Busch <keith.busch@intel.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Christoph Hellwig <hch@lst.de> Link: http://lkml.kernel.org/r/20170619235444.459397746@linutronix.de
This commit is contained in:
		
							parent
							
								
									ae904cafd5
								
							
						
					
					
						commit
						9dc6be3d41
					
				
					 2 changed files with 6 additions and 0 deletions
				
			
		| 
						 | 
				
			
			@ -130,6 +130,7 @@ struct irq_domain_chip_generic;
 | 
			
		|||
 * @host_data: private data pointer for use by owner.  Not touched by irq_domain
 | 
			
		||||
 *             core code.
 | 
			
		||||
 * @flags: host per irq_domain flags
 | 
			
		||||
 * @mapcount: The number of mapped interrupts
 | 
			
		||||
 *
 | 
			
		||||
 * Optional elements
 | 
			
		||||
 * @of_node: Pointer to device tree nodes associated with the irq_domain. Used
 | 
			
		||||
| 
						 | 
				
			
			@ -152,6 +153,7 @@ struct irq_domain {
 | 
			
		|||
	const struct irq_domain_ops *ops;
 | 
			
		||||
	void *host_data;
 | 
			
		||||
	unsigned int flags;
 | 
			
		||||
	unsigned int mapcount;
 | 
			
		||||
 | 
			
		||||
	/* Optional data */
 | 
			
		||||
	struct fwnode_handle *fwnode;
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -423,6 +423,7 @@ void irq_domain_disassociate(struct irq_domain *domain, unsigned int irq)
 | 
			
		|||
 | 
			
		||||
	irq_data->domain = NULL;
 | 
			
		||||
	irq_data->hwirq = 0;
 | 
			
		||||
	domain->mapcount--;
 | 
			
		||||
 | 
			
		||||
	/* Clear reverse map for this hwirq */
 | 
			
		||||
	if (hwirq < domain->revmap_size) {
 | 
			
		||||
| 
						 | 
				
			
			@ -474,6 +475,7 @@ int irq_domain_associate(struct irq_domain *domain, unsigned int virq,
 | 
			
		|||
			domain->name = irq_data->chip->name;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	domain->mapcount++;
 | 
			
		||||
	if (hwirq < domain->revmap_size) {
 | 
			
		||||
		domain->linear_revmap[hwirq] = virq;
 | 
			
		||||
	} else {
 | 
			
		||||
| 
						 | 
				
			
			@ -1081,6 +1083,7 @@ static void irq_domain_insert_irq(int virq)
 | 
			
		|||
		struct irq_domain *domain = data->domain;
 | 
			
		||||
		irq_hw_number_t hwirq = data->hwirq;
 | 
			
		||||
 | 
			
		||||
		domain->mapcount++;
 | 
			
		||||
		if (hwirq < domain->revmap_size) {
 | 
			
		||||
			domain->linear_revmap[hwirq] = virq;
 | 
			
		||||
		} else {
 | 
			
		||||
| 
						 | 
				
			
			@ -1110,6 +1113,7 @@ static void irq_domain_remove_irq(int virq)
 | 
			
		|||
		struct irq_domain *domain = data->domain;
 | 
			
		||||
		irq_hw_number_t hwirq = data->hwirq;
 | 
			
		||||
 | 
			
		||||
		domain->mapcount--;
 | 
			
		||||
		if (hwirq < domain->revmap_size) {
 | 
			
		||||
			domain->linear_revmap[hwirq] = 0;
 | 
			
		||||
		} else {
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in a new issue