mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	nvme-pci: qdepth 1 quirk
Another device has been reported to be unreliable if we have more than one outstanding command. In this new case, data corruption may occur. Since we have two devices now needing this quirky behavior, make a generic quirk flag. The same Apple quirk is clearly not "temporary", so update the comment while moving it. Link: https://lore.kernel.org/linux-nvme/191d810a4e3.fcc6066c765804.973611676137075390@collabora.com/ Reported-by: Robert Beckett <bob.beckett@collabora.com> Reviewed-by: Christoph Hellwig hch@lst.de> Signed-off-by: Keith Busch <kbusch@kernel.org>
This commit is contained in:
		
							parent
							
								
									2d5a333e09
								
							
						
					
					
						commit
						83bdfcbdbe
					
				| @ -90,6 +90,11 @@ enum nvme_quirks { | |||||||
| 	 */ | 	 */ | ||||||
| 	NVME_QUIRK_NO_DEEPEST_PS		= (1 << 5), | 	NVME_QUIRK_NO_DEEPEST_PS		= (1 << 5), | ||||||
| 
 | 
 | ||||||
|  | 	/*
 | ||||||
|  | 	 *  Problems seen with concurrent commands | ||||||
|  | 	 */ | ||||||
|  | 	NVME_QUIRK_QDEPTH_ONE			= (1 << 6), | ||||||
|  | 
 | ||||||
| 	/*
 | 	/*
 | ||||||
| 	 * Set MEDIUM priority on SQ creation | 	 * Set MEDIUM priority on SQ creation | ||||||
| 	 */ | 	 */ | ||||||
|  | |||||||
| @ -2557,15 +2557,8 @@ static int nvme_pci_enable(struct nvme_dev *dev) | |||||||
| 	else | 	else | ||||||
| 		dev->io_sqes = NVME_NVM_IOSQES; | 		dev->io_sqes = NVME_NVM_IOSQES; | ||||||
| 
 | 
 | ||||||
| 	/*
 | 	if (dev->ctrl.quirks & NVME_QUIRK_QDEPTH_ONE) { | ||||||
| 	 * Temporary fix for the Apple controller found in the MacBook8,1 and |  | ||||||
| 	 * some MacBook7,1 to avoid controller resets and data loss. |  | ||||||
| 	 */ |  | ||||||
| 	if (pdev->vendor == PCI_VENDOR_ID_APPLE && pdev->device == 0x2001) { |  | ||||||
| 		dev->q_depth = 2; | 		dev->q_depth = 2; | ||||||
| 		dev_warn(dev->ctrl.device, "detected Apple NVMe controller, " |  | ||||||
| 			"set queue depth=%u to work around controller resets\n", |  | ||||||
| 			dev->q_depth); |  | ||||||
| 	} else if (pdev->vendor == PCI_VENDOR_ID_SAMSUNG && | 	} else if (pdev->vendor == PCI_VENDOR_ID_SAMSUNG && | ||||||
| 		   (pdev->device == 0xa821 || pdev->device == 0xa822) && | 		   (pdev->device == 0xa821 || pdev->device == 0xa822) && | ||||||
| 		   NVME_CAP_MQES(dev->ctrl.cap) == 0) { | 		   NVME_CAP_MQES(dev->ctrl.cap) == 0) { | ||||||
| @ -3425,6 +3418,8 @@ static const struct pci_device_id nvme_id_table[] = { | |||||||
| 				NVME_QUIRK_BOGUS_NID, }, | 				NVME_QUIRK_BOGUS_NID, }, | ||||||
| 	{ PCI_VDEVICE(REDHAT, 0x0010),	/* Qemu emulated controller */ | 	{ PCI_VDEVICE(REDHAT, 0x0010),	/* Qemu emulated controller */ | ||||||
| 		.driver_data = NVME_QUIRK_BOGUS_NID, }, | 		.driver_data = NVME_QUIRK_BOGUS_NID, }, | ||||||
|  | 	{ PCI_DEVICE(0x1217, 0x8760), /* O2 Micro 64GB Steam Deck */ | ||||||
|  | 		.driver_data = NVME_QUIRK_QDEPTH_ONE }, | ||||||
| 	{ PCI_DEVICE(0x126f, 0x2262),	/* Silicon Motion generic */ | 	{ PCI_DEVICE(0x126f, 0x2262),	/* Silicon Motion generic */ | ||||||
| 		.driver_data = NVME_QUIRK_NO_DEEPEST_PS | | 		.driver_data = NVME_QUIRK_NO_DEEPEST_PS | | ||||||
| 				NVME_QUIRK_BOGUS_NID, }, | 				NVME_QUIRK_BOGUS_NID, }, | ||||||
| @ -3559,7 +3554,12 @@ static const struct pci_device_id nvme_id_table[] = { | |||||||
| 	{ PCI_DEVICE(PCI_VENDOR_ID_AMAZON, 0xcd02), | 	{ PCI_DEVICE(PCI_VENDOR_ID_AMAZON, 0xcd02), | ||||||
| 		.driver_data = NVME_QUIRK_DMA_ADDRESS_BITS_48, }, | 		.driver_data = NVME_QUIRK_DMA_ADDRESS_BITS_48, }, | ||||||
| 	{ PCI_DEVICE(PCI_VENDOR_ID_APPLE, 0x2001), | 	{ PCI_DEVICE(PCI_VENDOR_ID_APPLE, 0x2001), | ||||||
| 		.driver_data = NVME_QUIRK_SINGLE_VECTOR }, | 		/*
 | ||||||
|  | 		 * Fix for the Apple controller found in the MacBook8,1 and | ||||||
|  | 		 * some MacBook7,1 to avoid controller resets and data loss. | ||||||
|  | 		 */ | ||||||
|  | 		.driver_data = NVME_QUIRK_SINGLE_VECTOR | | ||||||
|  | 				NVME_QUIRK_QDEPTH_ONE }, | ||||||
| 	{ PCI_DEVICE(PCI_VENDOR_ID_APPLE, 0x2003) }, | 	{ PCI_DEVICE(PCI_VENDOR_ID_APPLE, 0x2003) }, | ||||||
| 	{ PCI_DEVICE(PCI_VENDOR_ID_APPLE, 0x2005), | 	{ PCI_DEVICE(PCI_VENDOR_ID_APPLE, 0x2005), | ||||||
| 		.driver_data = NVME_QUIRK_SINGLE_VECTOR | | 		.driver_data = NVME_QUIRK_SINGLE_VECTOR | | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Keith Busch
						Keith Busch