diff options
Diffstat (limited to 'kernel/irq/proc.c')
| -rw-r--r-- | kernel/irq/proc.c | 60 | 
1 files changed, 60 insertions, 0 deletions
| diff --git a/kernel/irq/proc.c b/kernel/irq/proc.c index 7a6eb04ef6b5..09a2ee540bd2 100644 --- a/kernel/irq/proc.c +++ b/kernel/irq/proc.c @@ -32,6 +32,27 @@ static int irq_affinity_proc_show(struct seq_file *m, void *v)  	return 0;  } +static int irq_affinity_hint_proc_show(struct seq_file *m, void *v) +{ +	struct irq_desc *desc = irq_to_desc((long)m->private); +	unsigned long flags; +	cpumask_var_t mask; + +	if (!zalloc_cpumask_var(&mask, GFP_KERNEL)) +		return -ENOMEM; + +	raw_spin_lock_irqsave(&desc->lock, flags); +	if (desc->affinity_hint) +		cpumask_copy(mask, desc->affinity_hint); +	raw_spin_unlock_irqrestore(&desc->lock, flags); + +	seq_cpumask(m, mask); +	seq_putc(m, '\n'); +	free_cpumask_var(mask); + +	return 0; +} +  #ifndef is_affinity_mask_valid  #define is_affinity_mask_valid(val) 1  #endif @@ -84,6 +105,11 @@ static int irq_affinity_proc_open(struct inode *inode, struct file *file)  	return single_open(file, irq_affinity_proc_show, PDE(inode)->data);  } +static int irq_affinity_hint_proc_open(struct inode *inode, struct file *file) +{ +	return single_open(file, irq_affinity_hint_proc_show, PDE(inode)->data); +} +  static const struct file_operations irq_affinity_proc_fops = {  	.open		= irq_affinity_proc_open,  	.read		= seq_read, @@ -92,6 +118,13 @@ static const struct file_operations irq_affinity_proc_fops = {  	.write		= irq_affinity_proc_write,  }; +static const struct file_operations irq_affinity_hint_proc_fops = { +	.open		= irq_affinity_hint_proc_open, +	.read		= seq_read, +	.llseek		= seq_lseek, +	.release	= single_release, +}; +  static int default_affinity_show(struct seq_file *m, void *v)  {  	seq_cpumask(m, irq_default_affinity); @@ -147,6 +180,26 @@ static const struct file_operations default_affinity_proc_fops = {  	.release	= single_release,  	.write		= default_affinity_write,  }; + +static int irq_node_proc_show(struct seq_file *m, void *v) +{ +	struct irq_desc *desc = irq_to_desc((long) m->private); + +	seq_printf(m, "%d\n", desc->node); +	return 0; +} + +static int irq_node_proc_open(struct inode *inode, struct file *file) +{ +	return single_open(file, irq_node_proc_show, PDE(inode)->data); +} + +static const struct file_operations irq_node_proc_fops = { +	.open		= irq_node_proc_open, +	.read		= seq_read, +	.llseek		= seq_lseek, +	.release	= single_release, +};  #endif  static int irq_spurious_proc_show(struct seq_file *m, void *v) @@ -231,6 +284,13 @@ void register_irq_proc(unsigned int irq, struct irq_desc *desc)  	/* create /proc/irq/<irq>/smp_affinity */  	proc_create_data("smp_affinity", 0600, desc->dir,  			 &irq_affinity_proc_fops, (void *)(long)irq); + +	/* create /proc/irq/<irq>/affinity_hint */ +	proc_create_data("affinity_hint", 0400, desc->dir, +			 &irq_affinity_hint_proc_fops, (void *)(long)irq); + +	proc_create_data("node", 0444, desc->dir, +			 &irq_node_proc_fops, (void *)(long)irq);  #endif  	proc_create_data("spurious", 0444, desc->dir, | 
