 27c9d80f51
			
		
	
	27c9d80f51
	
	
		
			
	
		
	
	
		
			Some checks failed
		
		
	
	Build Kernel / Build all affected Kernels (push) Has been cancelled
				
			Build all core packages / Build all core packages for selected target (push) Has been cancelled
				
			Build and Push prebuilt tools container / Build and Push all prebuilt containers (push) Has been cancelled
				
			Build Toolchains / Build Toolchains for each target (push) Has been cancelled
				
			Build host tools / Build host tools for linux and macos based systems (push) Has been cancelled
				
			Coverity scan build / Coverity x86/64 build (push) Has been cancelled
				
			
		
			
				
	
	
		
			81 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			81 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From 789d3eeb2367f92193a0882f7cdab03f0f9d6930 Mon Sep 17 00:00:00 2001
 | |
| From: Thomas Perrot <thomas.perrot@bootlin.com>
 | |
| Date: Thu, 16 Dec 2021 13:42:27 +0530
 | |
| Subject: [PATCH] bus: mhi: pci_generic: Introduce Sierra EM919X support
 | |
| 
 | |
| Add support for EM919X modems, this modem series is based on SDX55
 | |
| qcom chip.
 | |
| 
 | |
| It is mandatory to use the same ring for control+data and diag events.
 | |
| 
 | |
| Link: https://lore.kernel.org/r/20211123081541.648426-1-thomas.perrot@bootlin.com
 | |
| Tested-by: Aleksander Morgado <aleksander@aleksander.es>
 | |
| Reviewed-by: Manivannan Sadhasivam <mani@kernel.org>
 | |
| Signed-off-by: Thomas Perrot <thomas.perrot@bootlin.com>
 | |
| Signed-off-by: Manivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
 | |
| Link: https://lore.kernel.org/r/20211216081227.237749-11-manivannan.sadhasivam@linaro.org
 | |
| Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
 | |
| ---
 | |
|  drivers/bus/mhi/host/pci_generic.c | 43 +++++++++++++++++++++++++++++++++++
 | |
|  1 file changed, 43 insertions(+)
 | |
| 
 | |
| --- a/drivers/bus/mhi/host/pci_generic.c
 | |
| +++ b/drivers/bus/mhi/host/pci_generic.c
 | |
| @@ -406,6 +406,46 @@ static const struct mhi_pci_dev_info mhi
 | |
|  	.mru_default = 32768,
 | |
|  };
 | |
|  
 | |
| +static const struct mhi_channel_config mhi_sierra_em919x_channels[] = {
 | |
| +	MHI_CHANNEL_CONFIG_UL_SBL(2, "SAHARA", 32, 0),
 | |
| +	MHI_CHANNEL_CONFIG_DL_SBL(3, "SAHARA", 256, 0),
 | |
| +	MHI_CHANNEL_CONFIG_UL(4, "DIAG", 32, 0),
 | |
| +	MHI_CHANNEL_CONFIG_DL(5, "DIAG", 32, 0),
 | |
| +	MHI_CHANNEL_CONFIG_UL(12, "MBIM", 128, 0),
 | |
| +	MHI_CHANNEL_CONFIG_DL(13, "MBIM", 128, 0),
 | |
| +	MHI_CHANNEL_CONFIG_UL(14, "QMI", 32, 0),
 | |
| +	MHI_CHANNEL_CONFIG_DL(15, "QMI", 32, 0),
 | |
| +	MHI_CHANNEL_CONFIG_UL(32, "DUN", 32, 0),
 | |
| +	MHI_CHANNEL_CONFIG_DL(33, "DUN", 32, 0),
 | |
| +	MHI_CHANNEL_CONFIG_HW_UL(100, "IP_HW0", 512, 1),
 | |
| +	MHI_CHANNEL_CONFIG_HW_DL(101, "IP_HW0", 512, 2),
 | |
| +};
 | |
| +
 | |
| +static struct mhi_event_config modem_sierra_em919x_mhi_events[] = {
 | |
| +	/* first ring is control+data and DIAG ring */
 | |
| +	MHI_EVENT_CONFIG_CTRL(0, 2048),
 | |
| +	/* Hardware channels request dedicated hardware event rings */
 | |
| +	MHI_EVENT_CONFIG_HW_DATA(1, 2048, 100),
 | |
| +	MHI_EVENT_CONFIG_HW_DATA(2, 2048, 101)
 | |
| +};
 | |
| +
 | |
| +static const struct mhi_controller_config modem_sierra_em919x_config = {
 | |
| +	.max_channels = 128,
 | |
| +	.timeout_ms = 24000,
 | |
| +	.num_channels = ARRAY_SIZE(mhi_sierra_em919x_channels),
 | |
| +	.ch_cfg = mhi_sierra_em919x_channels,
 | |
| +	.num_events = ARRAY_SIZE(modem_sierra_em919x_mhi_events),
 | |
| +	.event_cfg = modem_sierra_em919x_mhi_events,
 | |
| +};
 | |
| +
 | |
| +static const struct mhi_pci_dev_info mhi_sierra_em919x_info = {
 | |
| +	.name = "sierra-em919x",
 | |
| +	.config = &modem_sierra_em919x_config,
 | |
| +	.bar_num = MHI_PCI_DEFAULT_BAR_NUM,
 | |
| +	.dma_data_width = 32,
 | |
| +	.sideband_wake = false,
 | |
| +};
 | |
| +
 | |
|  static const struct mhi_channel_config mhi_telit_fn980_hw_v1_channels[] = {
 | |
|  	MHI_CHANNEL_CONFIG_UL(14, "QMI", 32, 0),
 | |
|  	MHI_CHANNEL_CONFIG_DL(15, "QMI", 32, 0),
 | |
| @@ -480,6 +520,9 @@ static const struct mhi_pci_dev_info mhi
 | |
|  };
 | |
|  
 | |
|  static const struct pci_device_id mhi_pci_id_table[] = {
 | |
| +	/* EM919x (sdx55), use the same vid:pid as qcom-sdx55m */
 | |
| +	{ PCI_DEVICE_SUB(PCI_VENDOR_ID_QCOM, 0x0306, 0x18d7, 0x0200),
 | |
| +		.driver_data = (kernel_ulong_t) &mhi_sierra_em919x_info },
 | |
|  	/* Telit FN980 hardware revision v1 */
 | |
|  	{ PCI_DEVICE_SUB(PCI_VENDOR_ID_QCOM, 0x0306, 0x1C5D, 0x2000),
 | |
|  		.driver_data = (kernel_ulong_t) &mhi_telit_fn980_hw_v1_info },
 |