Paolo Bonzini ae79c2db15 
	
	
	ahci: fix FIS I bit and PIO Setup FIS interrupt ... 
			The "I" bit in PIO Setup and D2H FISes is exclusively a device concept
and the irqstatus register in the controller does not matter.  The SATA
spec says when it should be one; for D2H FISes in practice it is always
set, while the PIO Setup FIS has several subcases that are documented in
the patch.
Also, the PIO Setup FIS interrupt is actually generated _after_ data
has been received.
Someone should probably spend some time reading the SATA specification and
figuring out the more obscure fields in the PIO Setup FIS, but this is enough
to fix SeaBIOS booting from ATAPI CD-ROMs over an AHCI controller.
Fixes: 956556e131kraxel@redhat.com >
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com >
Reviewed-by: John Snow <jsnow@redhat.com >
Message-id: 20180622165159.19863-1-pbonzini@redhat.com 
[Minor edit to avoid ATAPI comment ambiguity. --js]
Signed-off-by: John Snow <jsnow@redhat.com > 
		
	 
		2018-06-25 16:50:48 -04:00 
	 
	
	
	
		 
	
	
		
			
			
			
			
			
			2018-06-15 16:10:11 -03:00 
		 
	
		
			
			
			
			
			
			2018-06-11 22:19:57 +03:00 
		 
	
		
			
			
			
			
			
			2017-07-18 05:49:01 -05:00 
		 
	
		
			
			
			
			
			
			2018-02-22 15:44:07 -08:00 
		 
	
		
			
			
			
			
			
			2018-06-20 22:13:39 +01:00 
		 
	
		
			
			
			
			
			
			2018-06-08 14:39:24 -03:00 
		 
	
		
			
			
			
			
			
			2018-06-08 14:39:24 -03:00 
		 
	
		
			
			
			
			
			
			2017-09-22 10:46:25 +08:00 
		 
	
		
			
			
			
			
			
			2018-06-25 16:50:48 -04:00 
		 
	
		
			
			
			
			
			
			2018-06-08 14:39:24 -03:00 
		 
	
		
			
			
			
			
			
			2018-03-21 15:13:40 +01:00 
		 
	
		
			
			
			
			
			
			2018-06-22 16:33:46 +02:00 
		 
	
		
			
			
			
			
			
			2018-06-18 17:05:17 +02:00 
		 
	
		
			
			
			
			
			
			2017-07-11 17:45:00 +02:00 
		 
	
		
			
			
			
			
			
			2018-06-20 22:13:32 +01:00 
		 
	
		
			
			
			
			
			
			2018-06-08 14:39:24 -03:00 
		 
	
		
	
		
			
			
			
			
			
			2018-06-21 09:21:19 -05:00 
		 
	
		
			
			
			
			
			
			2016-06-07 18:19:24 +03:00 
		 
	
		
			
			
			
			
			
			2017-03-02 07:14:27 +02:00 
		 
	
		
			
			
			
			
			
			2018-01-16 14:54:52 +01:00 
		 
	
		
			
			
			
			
			
			2018-06-15 14:49:44 +02:00 
		 
	
		
			
			
			
			
			
			2016-10-26 08:29:01 -07:00 
		 
	
		
			
			
			
			
			
			2017-09-04 10:45:19 +01:00 
		 
	
		
			
			
			
			
			
			2017-09-04 10:45:19 +01:00 
		 
	
		
			
			
			
			
			
			2017-09-04 10:45:19 +01:00 
		 
	
		
			
			
			
			
			
			2018-06-11 22:19:57 +03:00 
		 
	
		
			
			
			
			
			
			2018-02-14 11:43:41 +01:00 
		 
	
		
			
			
			
			
			
			2018-06-08 13:17:39 -04:00 
		 
	
		
			
			
			
			
			
			2018-02-14 11:43:41 +01:00 
		 
	
		
			
			
			
			
			
			2018-04-30 10:48:29 +02:00 
		 
	
		
			
			
			
			
			
			2018-06-08 13:17:39 -04:00 
		 
	
		
			
			
			
			
			
			2018-06-22 16:33:46 +02:00 
		 
	
		
			
			
			
			
			
			2016-09-23 13:36:09 +02:00 
		 
	
		
			
			
			
			
			
			2018-06-15 14:49:44 +02:00 
		 
	
		
			
			
			
			
			
			2018-05-04 08:27:53 +02:00 
		 
	
		
			
			
			
			
			
			2018-05-04 08:27:53 +02:00 
		 
	
		
			
			
			
			
			
			2018-05-04 08:27:53 +02:00 
		 
	
		
			
			
			
			
			
			2018-05-04 08:27:53 +02:00 
		 
	
		
			
			
			
			
			
			2018-05-04 08:27:53 +02:00 
		 
	
		
			
			
			
			
			
			2018-06-15 14:49:44 +02:00 
		 
	
		
			
			
			
			
			
			2016-09-08 17:57:32 +04:00 
		 
	
		
			
			
			
			
			
			2017-09-04 13:09:13 +02:00 
		 
	
		
			
			
			
			
			
			2018-05-04 08:27:53 +02:00 
		 
	
		
			
			
			
			
			
			2018-05-04 08:27:53 +02:00 
		 
	
		
			
			
			
			
			
			2017-09-04 10:45:19 +01:00 
		 
	
		
			
			
			
			
			
			2016-10-28 18:17:24 +03:00 
		 
	
		
			
			
			
			
			
			2018-05-04 08:27:53 +02:00 
		 
	
		
			
			
			
			
			
			2017-01-31 10:10:13 +11:00 
		 
	
		
			
			
			
			
			
			2018-05-04 08:27:53 +02:00 
		 
	
		
			
			
			
			
			
			2018-02-14 11:43:41 +01:00 
		 
	
		
			
			
			
			
			
			2017-03-01 11:51:28 +04:00 
		 
	
		
			
			
			
			
			
			2018-02-14 11:43:41 +01:00 
		 
	
		
			
			
			
			
			
			2017-03-01 11:51:05 +04:00 
		 
	
		
			
			
			
			
			
			2017-10-20 13:32:10 +02:00 
		 
	
		
			
			
			
			
			
			2016-06-07 18:19:24 +03:00 
		 
	
		
			
			
			
			
			
			2017-05-09 09:14:40 +02:00 
		 
	
		
			
			
			
			
			
			2018-02-14 11:43:41 +01:00 
		 
	
		
			
			
			
			
			
			2018-06-15 14:49:44 +02:00 
		 
	
		
			
			
			
			
			
			2018-02-14 11:43:02 +01:00 
		 
	
		
			
			
			
			
			
			2016-06-07 18:19:24 +03:00 
		 
	
		
			
			
			
			
			
			2018-06-15 14:49:44 +02:00 
		 
	
		
			
			
			
			
			
			2016-06-20 16:38:13 +02:00 
		 
	
		
			
			
			
			
			
			2018-02-09 13:50:17 +01:00 
		 
	
		
			
			
			
			
			
			2015-12-18 12:18:31 +00:00 
		 
	
		
			
			
			
			
			
			2016-06-07 18:19:24 +03:00 
		 
	
		
			
			
			
			
			
			2017-02-21 11:14:07 +00:00 
		 
	
		
			
			
			
			
			
			2017-02-21 11:14:07 +00:00 
		 
	
		
			
			
			
			
			
			2017-10-20 13:32:10 +02:00 
		 
	
		
			
			
			
			
			
			2017-03-01 11:51:05 +04:00 
		 
	
		
			
			
			
			
			
			2016-06-07 18:19:24 +03:00 
		 
	
		
			
			
			
			
			
			2018-02-14 11:43:41 +01:00 
		 
	
		
			
			
			
			
			
			2018-06-04 10:15:16 +01:00 
		 
	
		
			
			
			
			
			
			2018-05-30 13:19:14 -03:00 
		 
	
		
			
			
			
			
			
			2017-10-20 13:32:10 +02:00 
		 
	
		
			
			
			
			
			
			2018-05-20 08:48:13 +03:00 
		 
	
		
			
			
			
			
			
			2018-05-04 08:27:53 +02:00 
		 
	
		
			
			
			
			
			
			2018-06-22 16:33:47 +02:00 
		 
	
		
			
			
			
			
			
			2018-02-14 11:43:41 +01:00 
		 
	
		
			
			
			
			
			
			2018-05-15 20:24:27 +02:00 
		 
	
		
			
			
			
			
			
			2016-06-07 18:19:24 +03:00 
		 
	
		
			
			
			
			
			
			2018-05-30 13:19:14 -03:00 
		 
	
		
			
			
			
			
			
			2017-05-11 11:08:40 +02:00 
		 
	
		
			
			
			
			
			
			2018-06-08 13:15:32 +01:00 
		 
	
		
			
			
			
			
			
			2016-06-07 18:19:24 +03:00 
		 
	
		
			
			
			
			
			
			2016-10-19 10:09:24 +01:00 
		 
	
		
			
			
			
			
			
			2018-01-17 09:35:24 +11:00 
		 
	
		
			
			
			
			
			
			2017-10-20 13:32:10 +02:00 
		 
	
		
			
			
			
			
			
			2017-09-19 16:19:39 +02:00 
		 
	
		
			
			
			
			
			
			2018-02-09 05:05:11 +01:00 
		 
	
		
			
			
			
			
			
			2016-10-24 16:26:53 +01:00 
		 
	
		
			
			
			
			
			
			2018-05-04 08:27:53 +02:00 
		 
	
		
			
			
			
			
			
			2018-02-14 11:43:41 +01:00 
		 
	
		
			
			
			
			
			
			2018-05-04 08:27:53 +02:00 
		 
	
		
			
			
			
			
			
			2015-01-13 11:47:55 +00:00 
		 
	
		
			
			
			
			
			
			2018-06-15 07:42:55 -10:00 
		 
	
		
			
			
			
			
			
			2018-05-30 13:19:14 -03:00 
		 
	
		
			
			
			
			
			
			2018-05-04 08:27:53 +02:00 
		 
	
		
			
			
			
			
			
			2018-03-12 16:12:47 +01:00 
		 
	
		
			
			
			
			
			
			2018-02-14 11:43:41 +01:00 
		 
	
		
			
			
			
			
			
			2017-08-01 17:27:33 +02:00 
		 
	
		
			
			
			
			
			
			2018-02-14 11:43:02 +01:00 
		 
	
		
			
			
			
			
			
			2018-03-06 14:01:27 +01:00 
		 
	
		
			
			
			
			
			
			2018-03-13 18:06:06 +00:00 
		 
	
		
			
			
			
			
			
			2018-03-13 18:06:06 +00:00 
		 
	
		
			
			
			
			
			
			2016-10-16 12:04:15 +11:00 
		 
	
		
			
			
			
			
			
			2018-05-04 08:27:53 +02:00 
		 
	
		
			
			
			
			
			
			2018-02-09 13:50:17 +01:00 
		 
	
		
			
			
			
			
			
			2018-03-27 13:05:28 +01:00 
		 
	
		
			
			
			
			
			
			2016-10-24 16:26:54 +01:00 
		 
	
		
			
			
			
			
			
			2016-06-07 18:19:24 +03:00 
		 
	
		
			
			
			
			
			
			2018-06-18 15:03:25 +02:00 
		 
	
		
			
			
			
			
			
			2017-01-10 08:49:59 -08:00 
		 
	
		
			
			
			
			
			
			2016-06-17 15:23:51 +01:00 
		 
	
		
			
			
			
			
			
			2018-03-02 18:39:07 +01:00 
		 
	
		
			
			
			
			
			
			2018-05-30 13:31:01 +02:00 
		 
	
		
			
			
			
			
			
			2018-05-30 13:31:01 +02:00 
		 
	
		
			
			
			
			
			
			2016-09-13 19:13:32 +02:00 
		 
	
		
			
			
			
			
			
			2018-06-01 15:13:46 +02:00 
		 
	
		
			
			
			
			
			
			2018-02-09 13:52:15 +01:00 
		 
	
		
			
			
			
			
			
			2018-02-08 09:22:03 +08:00 
		 
	
		
			
			
			
			
			
			2016-03-22 22:20:15 +01:00 
		 
	
		
			
			
			
			
			
			2017-11-08 11:03:46 +00:00 
		 
	
		
			
			
			
			
			
			2016-12-21 14:26:26 +00:00 
		 
	
		
			
			
			
			
			
			2016-10-19 10:23:55 +01:00 
		 
	
		
			
			
			
			
			
			2016-12-22 09:24:59 +00:00 
		 
	
		
			
			
			
			
			
			2016-03-22 22:20:15 +01:00 
		 
	
		
			
			
			
			
			
			2016-09-19 16:30:45 +01:00 
		 
	
		
			
			
			
			
			
			2016-06-13 12:41:17 +01:00 
		 
	
		
			
			
			
			
			
			2016-03-22 22:20:15 +01:00 
		 
	
		
			
			
			
			
			
			2018-04-06 11:28:31 +01:00 
		 
	
		
			
			
			
			
			
			2016-07-04 10:46:59 +01:00 
		 
	
		
			
			
			
			
			
			2018-03-13 18:06:05 +00:00 
		 
	
		
			
			
			
			
			
			2017-10-20 13:32:10 +02:00 
		 
	
		
			
			
			
			
			
			2018-02-07 14:09:25 +01:00 
		 
	
		
			
			
			
			
			
			2018-06-18 17:04:56 +02:00 
		 
	
		
			
			
			
			
			
			2018-03-05 10:30:15 +08:00 
		 
	
		
			
			
			
			
			
			2016-10-26 08:29:00 -07:00 
		 
	
		
			
			
			
			
			
			2016-02-16 14:29:27 +00:00 
		 
	
		
			
			
			
			
			
			2017-03-01 00:09:28 +04:00 
		 
	
		
			
			
			
			
			
			2018-02-15 16:54:57 +00:00 
		 
	
		
			
			
			
			
			
			2018-03-13 18:06:06 +00:00 
		 
	
		
			
			
			
			
			
			2018-04-06 11:28:31 +01:00 
		 
	
		
			
			
			
			
			
			2018-03-06 10:19:05 +00:00 
		 
	
		
			
			
			
			
			
			2017-09-05 22:34:40 +02:00 
		 
	
		
			
			
			
			
			
			2018-05-04 08:27:53 +02:00 
		 
	
		
			
			
			
			
			
			2016-08-19 12:44:11 +01:00 
		 
	
		
			
			
			
			
			
			2016-06-07 18:19:24 +03:00 
		 
	
		
			
			
			
			
			
			2018-05-04 08:27:53 +02:00 
		 
	
		
			
			
			
			
			
			2017-03-22 19:24:34 +01:00 
		 
	
		
			
			
			
			
			
			2018-02-09 05:05:11 +01:00 
		 
	
		
			
			
			
			
			
			2017-07-17 15:41:30 -03:00 
		 
	
		
			
			
			
			
			
			2016-08-03 18:44:56 +02:00 
		 
	
		
			
			
			
			
			
			2018-05-09 00:13:39 +02:00 
		 
	
		
			
			
			
			
			
			2018-05-04 08:27:53 +02:00 
		 
	
		
			
			
			
			
			
			2016-06-16 18:39:03 +02:00 
		 
	
		
			
			
			
			
			
			2018-06-15 07:42:55 -10:00 
		 
	
		
			
			
			
			
			
			2018-05-30 13:19:14 -03:00 
		 
	
		
			
			
			
			
			
			2018-05-04 08:27:53 +02:00 
		 
	
		
			
			
			
			
			
			2018-05-04 08:27:53 +02:00 
		 
	
		
			
			
			
			
			
			2018-05-04 08:27:53 +02:00 
		 
	
		
			
			
			
			
			
			2016-06-07 18:19:24 +03:00 
		 
	
		
			
			
			
			
			
			2018-06-15 14:49:44 +02:00 
		 
	
		
			
			
			
			
			
			2017-01-31 10:10:14 +11:00 
		 
	
		
			
			
			
			
			
			2018-02-09 13:52:15 +01:00 
		 
	
		
			
			
			
			
			
			2018-02-10 10:45:14 +03:00 
		 
	
		
			
			
			
			
			
			2018-05-20 08:48:13 +03:00 
		 
	
		
			
			
			
			
			
			2017-09-05 18:12:21 +02:00 
		 
	
		
			
			
			
			
			
			2016-06-07 18:19:24 +03:00 
		 
	
		
			
			
			
			
			
			2018-03-13 18:06:06 +00:00 
		 
	
		
			
			
			
			
			
			2017-12-20 22:01:24 +08:00 
		 
	
		
			
			
			
			
			
			2018-05-04 08:27:53 +02:00 
		 
	
		
			
			
			
			
			
			2017-09-27 11:44:18 +01:00 
		 
	
		
			
			
			
			
			
			2016-06-07 18:19:24 +03:00 
		 
	
		
			
			
			
			
			
			2018-05-04 08:27:53 +02:00 
		 
	
		
			
			
			
			
			
			2016-06-07 18:19:24 +03:00 
		 
	
		
			
			
			
			
			
			2017-05-18 18:04:54 +02:00 
		 
	
		
			
			
			
			
			
			2018-06-08 13:15:32 +01:00 
		 
	
		
			
			
			
			
			
			2016-06-07 18:19:24 +03:00 
		 
	
		
			
			
			
			
			
			2018-06-06 15:44:07 -04:00 
		 
	
		
			
			
			
			
			
			2018-03-29 17:41:03 -04:00 
		 
	
		
			
			
			
			
			
			2018-05-20 08:38:38 +03:00 
		 
	
		
			
			
			
			
			
			2018-02-21 07:24:50 -05:00 
		 
	
		
			
			
			
			
			
			2018-06-06 15:44:07 -04:00 
		 
	
		
			
			
			
			
			
			2018-06-06 15:44:07 -04:00 
		 
	
		
			
			
			
			
			
			2018-06-06 15:44:12 -04:00 
		 
	
		
			
			
			
			
			
			2018-02-21 07:24:50 -05:00 
		 
	
		
			
			
			
			
			
			2018-06-06 15:44:12 -04:00 
		 
	
		
			
			
			
			
			
			2018-06-06 15:44:12 -04:00 
		 
	
		
			
			
			
			
			
			2018-02-14 11:43:02 +01:00 
		 
	
		
			
			
			
			
			
			2016-06-07 18:19:24 +03:00 
		 
	
		
			
			
			
			
			
			2018-02-14 11:43:41 +01:00 
		 
	
		
			
			
			
			
			
			2018-06-12 12:07:30 +02:00 
		 
	
		
			
			
			
			
			
			2018-05-24 21:14:11 +03:00 
		 
	
		
			
			
			
			
			
			2018-05-04 08:27:53 +02:00 
		 
	
		
			
			
			
			
			
			2018-02-14 11:43:41 +01:00 
		 
	
		
			
			
			
			
			
			2017-10-20 13:32:10 +02:00 
		 
	
		
			
			
			
			
			
			2018-02-14 11:43:41 +01:00 
		 
	
		
			
			
			
			
			
			2017-10-20 13:32:10 +02:00 
		 
	
		
			
			
			
			
			
			2018-05-04 08:27:53 +02:00 
		 
	
		
			
			
			
			
			
			2016-10-28 09:36:58 +11:00 
		 
	
		
			
			
			
			
			
			2018-03-12 16:12:46 +01:00 
		 
	
		
			
			
			
			
			
			2017-10-20 13:32:10 +02:00 
		 
	
		
			
			
			
			
			
			2018-05-04 08:27:53 +02:00 
		 
	
		
			
			
			
			
			
			2016-06-07 18:19:24 +03:00 
		 
	
		
			
			
			
			
			
			2018-05-04 08:27:53 +02:00