mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-10-31 08:44:41 +00:00 
			
		
		
		
	spmi: spmi-pmic-arb: Fix hw_irq overflow
Currently, when handling the SPMI summary interrupt, the hw_irq number is calculated based on SID, Peripheral ID, IRQ index and APID. This is then passed to irq_find_mapping() to see if a mapping exists for this hw_irq and if available, invoke the interrupt handler. Since the IRQ index uses an "int" type, hw_irq which is of unsigned long data type can take a large value when SID has its MSB set to 1 and the type conversion happens. Because of this, irq_find_mapping() returns 0 as there is no mapping for this hw_irq. This ends up invoking cleanup_irq() as if the interrupt is spurious whereas it is actually a valid interrupt. Fix this by using the proper data type (u32) for id. Cc: stable@vger.kernel.org Signed-off-by: Subbaraman Narayanamurthy <subbaram@codeaurora.org> Link: https://lore.kernel.org/r/1612812784-26369-1-git-send-email-subbaram@codeaurora.org Signed-off-by: Stephen Boyd <sboyd@kernel.org> Link: https://lore.kernel.org/r/20210212031417.3148936-1-sboyd@kernel.org Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
		
							parent
							
								
									d77b44d0c0
								
							
						
					
					
						commit
						d19db80a36
					
				
					 1 changed files with 2 additions and 3 deletions
				
			
		|  | @ -1,6 +1,6 @@ | |||
| // SPDX-License-Identifier: GPL-2.0-only
 | ||||
| /*
 | ||||
|  * Copyright (c) 2012-2015, 2017, The Linux Foundation. All rights reserved. | ||||
|  * Copyright (c) 2012-2015, 2017, 2021, The Linux Foundation. All rights reserved. | ||||
|  */ | ||||
| #include <linux/bitmap.h> | ||||
| #include <linux/delay.h> | ||||
|  | @ -505,8 +505,7 @@ static void cleanup_irq(struct spmi_pmic_arb *pmic_arb, u16 apid, int id) | |||
| static void periph_interrupt(struct spmi_pmic_arb *pmic_arb, u16 apid) | ||||
| { | ||||
| 	unsigned int irq; | ||||
| 	u32 status; | ||||
| 	int id; | ||||
| 	u32 status, id; | ||||
| 	u8 sid = (pmic_arb->apid_data[apid].ppid >> 8) & 0xF; | ||||
| 	u8 per = pmic_arb->apid_data[apid].ppid & 0xFF; | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue
	
	 Subbaraman Narayanamurthy
						Subbaraman Narayanamurthy