mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	rsi: reset device changes for 9116
Device reset register(watchdog timer related) addresses and values are different for 9116. Signed-off-by: Siva Rebbagondla <siva8118@gmail.com> Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
This commit is contained in:
		
							parent
							
								
									1533f976c6
								
							
						
					
					
						commit
						17ff2c794f
					
				| @ -1167,16 +1167,41 @@ static void rsi_reset_chip(struct rsi_hw *adapter) | |||||||
| 	 * and any pending dma transfers to rf spi in device to finish. | 	 * and any pending dma transfers to rf spi in device to finish. | ||||||
| 	 */ | 	 */ | ||||||
| 	msleep(100); | 	msleep(100); | ||||||
| 
 | 	if (adapter->device_model != RSI_DEV_9116) { | ||||||
| 		ulp_read_write(adapter, RSI_ULP_RESET_REG, RSI_ULP_WRITE_0, 32); | 		ulp_read_write(adapter, RSI_ULP_RESET_REG, RSI_ULP_WRITE_0, 32); | ||||||
| 	ulp_read_write(adapter, RSI_WATCH_DOG_TIMER_1, RSI_ULP_WRITE_2, 32); | 		ulp_read_write(adapter, | ||||||
| 	ulp_read_write(adapter, RSI_WATCH_DOG_TIMER_2, RSI_ULP_WRITE_0, 32); | 			       RSI_WATCH_DOG_TIMER_1, RSI_ULP_WRITE_2, 32); | ||||||
| 	ulp_read_write(adapter, RSI_WATCH_DOG_DELAY_TIMER_1, RSI_ULP_WRITE_50, | 		ulp_read_write(adapter, RSI_WATCH_DOG_TIMER_2, RSI_ULP_WRITE_0, | ||||||
| 		       32); |  | ||||||
| 	ulp_read_write(adapter, RSI_WATCH_DOG_DELAY_TIMER_2, RSI_ULP_WRITE_0, |  | ||||||
| 			       32); | 			       32); | ||||||
|  | 		ulp_read_write(adapter, RSI_WATCH_DOG_DELAY_TIMER_1, | ||||||
|  | 			       RSI_ULP_WRITE_50, 32); | ||||||
|  | 		ulp_read_write(adapter, RSI_WATCH_DOG_DELAY_TIMER_2, | ||||||
|  | 			       RSI_ULP_WRITE_0, 32); | ||||||
| 		ulp_read_write(adapter, RSI_WATCH_DOG_TIMER_ENABLE, | 		ulp_read_write(adapter, RSI_WATCH_DOG_TIMER_ENABLE, | ||||||
| 			       RSI_ULP_TIMER_ENABLE, 32); | 			       RSI_ULP_TIMER_ENABLE, 32); | ||||||
|  | 	} else { | ||||||
|  | 		if ((rsi_sdio_master_reg_write(adapter, | ||||||
|  | 					       NWP_WWD_INTERRUPT_TIMER, | ||||||
|  | 					       NWP_WWD_INT_TIMER_CLKS, | ||||||
|  | 					       RSI_9116_REG_SIZE)) < 0) { | ||||||
|  | 			rsi_dbg(ERR_ZONE, "Failed to write to intr timer\n"); | ||||||
|  | 		} | ||||||
|  | 		if ((rsi_sdio_master_reg_write(adapter, | ||||||
|  | 					       NWP_WWD_SYSTEM_RESET_TIMER, | ||||||
|  | 					       NWP_WWD_SYS_RESET_TIMER_CLKS, | ||||||
|  | 					       RSI_9116_REG_SIZE)) < 0) { | ||||||
|  | 			rsi_dbg(ERR_ZONE, | ||||||
|  | 				"Failed to write to system reset timer\n"); | ||||||
|  | 		} | ||||||
|  | 		if ((rsi_sdio_master_reg_write(adapter, | ||||||
|  | 					       NWP_WWD_MODE_AND_RSTART, | ||||||
|  | 					       NWP_WWD_TIMER_DISABLE, | ||||||
|  | 					       RSI_9116_REG_SIZE)) < 0) { | ||||||
|  | 			rsi_dbg(ERR_ZONE, | ||||||
|  | 				"Failed to write to mode and restart\n"); | ||||||
|  | 		} | ||||||
|  | 		rsi_dbg(ERR_ZONE, "***** Watch Dog Reset Successful *****\n"); | ||||||
|  | 	} | ||||||
| 	/* This msleep will be sufficient for the ulp
 | 	/* This msleep will be sufficient for the ulp
 | ||||||
| 	 * read write operations to complete for chip reset. | 	 * read write operations to complete for chip reset. | ||||||
| 	 */ | 	 */ | ||||||
|  | |||||||
| @ -698,6 +698,7 @@ static int rsi_reset_card(struct rsi_hw *adapter) | |||||||
| 		goto fail; | 		goto fail; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	if (adapter->device_model != RSI_DEV_9116) { | ||||||
| 		ret = usb_ulp_read_write(adapter, RSI_WATCH_DOG_TIMER_1, | 		ret = usb_ulp_read_write(adapter, RSI_WATCH_DOG_TIMER_1, | ||||||
| 					 RSI_ULP_WRITE_2, 32); | 					 RSI_ULP_WRITE_2, 32); | ||||||
| 		if (ret < 0) | 		if (ret < 0) | ||||||
| @ -718,6 +719,26 @@ static int rsi_reset_card(struct rsi_hw *adapter) | |||||||
| 					 RSI_ULP_TIMER_ENABLE, 32); | 					 RSI_ULP_TIMER_ENABLE, 32); | ||||||
| 		if (ret < 0) | 		if (ret < 0) | ||||||
| 			goto fail; | 			goto fail; | ||||||
|  | 	} else { | ||||||
|  | 		if ((rsi_usb_master_reg_write(adapter, | ||||||
|  | 					      NWP_WWD_INTERRUPT_TIMER, | ||||||
|  | 					      NWP_WWD_INT_TIMER_CLKS, | ||||||
|  | 					      RSI_9116_REG_SIZE)) < 0) { | ||||||
|  | 			goto fail; | ||||||
|  | 		} | ||||||
|  | 		if ((rsi_usb_master_reg_write(adapter, | ||||||
|  | 					      NWP_WWD_SYSTEM_RESET_TIMER, | ||||||
|  | 					      NWP_WWD_SYS_RESET_TIMER_CLKS, | ||||||
|  | 					      RSI_9116_REG_SIZE)) < 0) { | ||||||
|  | 			goto fail; | ||||||
|  | 		} | ||||||
|  | 		if ((rsi_usb_master_reg_write(adapter, | ||||||
|  | 					      NWP_WWD_MODE_AND_RSTART, | ||||||
|  | 					      NWP_WWD_TIMER_DISABLE, | ||||||
|  | 					      RSI_9116_REG_SIZE)) < 0) { | ||||||
|  | 			goto fail; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| 	rsi_dbg(INFO_ZONE, "Reset card done\n"); | 	rsi_dbg(INFO_ZONE, "Reset card done\n"); | ||||||
| 	return ret; | 	return ret; | ||||||
|  | |||||||
| @ -70,6 +70,21 @@ | |||||||
| #define RSI_WATCH_DOG_DELAY_TIMER_2		0x16f | #define RSI_WATCH_DOG_DELAY_TIMER_2		0x16f | ||||||
| #define RSI_WATCH_DOG_TIMER_ENABLE		0x170 | #define RSI_WATCH_DOG_TIMER_ENABLE		0x170 | ||||||
| 
 | 
 | ||||||
|  | /* Watchdog timer addresses for 9116 */ | ||||||
|  | #define NWP_AHB_BASE_ADDR		0x41300000 | ||||||
|  | #define NWP_WWD_INTERRUPT_TIMER		(NWP_AHB_BASE_ADDR + 0x300) | ||||||
|  | #define NWP_WWD_SYSTEM_RESET_TIMER	(NWP_AHB_BASE_ADDR + 0x304) | ||||||
|  | #define NWP_WWD_WINDOW_TIMER		(NWP_AHB_BASE_ADDR + 0x308) | ||||||
|  | #define NWP_WWD_TIMER_SETTINGS		(NWP_AHB_BASE_ADDR + 0x30C) | ||||||
|  | #define NWP_WWD_MODE_AND_RSTART		(NWP_AHB_BASE_ADDR + 0x310) | ||||||
|  | #define NWP_WWD_RESET_BYPASS		(NWP_AHB_BASE_ADDR + 0x314) | ||||||
|  | #define NWP_FSM_INTR_MASK_REG		(NWP_AHB_BASE_ADDR + 0x104) | ||||||
|  | 
 | ||||||
|  | /* Watchdog timer values */ | ||||||
|  | #define NWP_WWD_INT_TIMER_CLKS		5 | ||||||
|  | #define NWP_WWD_SYS_RESET_TIMER_CLKS	4 | ||||||
|  | #define NWP_WWD_TIMER_DISABLE		0xAA0001 | ||||||
|  | 
 | ||||||
| #define RSI_ULP_WRITE_0			00 | #define RSI_ULP_WRITE_0			00 | ||||||
| #define RSI_ULP_WRITE_2			02 | #define RSI_ULP_WRITE_2			02 | ||||||
| #define RSI_ULP_WRITE_50		50 | #define RSI_ULP_WRITE_50		50 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Siva Rebbagondla
						Siva Rebbagondla