dcavalca / rpms / grub2

Forked from rpms/grub2 3 years ago
Clone

Blame SOURCES/0053-grub-core-disk-ahci.c-Add-safety-cleanups.patch

28f7f8
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
39700a
From: Vladimir Serbinenko <phcoder@gmail.com>
39700a
Date: Wed, 29 Jan 2014 23:46:17 +0100
28f7f8
Subject: [PATCH] * grub-core/disk/ahci.c: Add safety cleanups.
39700a
39700a
---
39700a
 grub-core/disk/ahci.c | 10 ++++++++++
28f7f8
 ChangeLog             |  4 ++++
39700a
 2 files changed, 14 insertions(+)
39700a
39700a
diff --git a/grub-core/disk/ahci.c b/grub-core/disk/ahci.c
28f7f8
index d63fd09fdc6..643e691ef80 100644
39700a
--- a/grub-core/disk/ahci.c
39700a
+++ b/grub-core/disk/ahci.c
39700a
@@ -454,6 +454,7 @@ grub_ahci_pciinit (grub_pci_device_t dev,
39700a
 	adevs[i]->hba->ports[adevs[i]->port].fis_base = grub_dma_get_phys (adevs[i]->rfis);
39700a
 	adevs[i]->hba->ports[adevs[i]->port].command_list_base
39700a
 	  = grub_dma_get_phys (adevs[i]->command_list_chunk);
39700a
+	adevs[i]->hba->ports[adevs[i]->port].command_issue = 0;
39700a
 	adevs[i]->hba->ports[adevs[i]->port].command |= GRUB_AHCI_HBA_PORT_CMD_FRE;
39700a
       }
39700a
 
39700a
@@ -600,6 +601,9 @@ grub_ahci_pciinit (grub_pci_device_t dev,
39700a
 	failed_adevs[i] = adevs[i];
39700a
 	adevs[i] = 0;
39700a
       }
39700a
+
39700a
+  grub_dprintf ("ahci", "cleaning up failed devs\n");
39700a
+
39700a
   for (i = 0; i < nports; i++)
39700a
     if (failed_adevs[i] && (fr_running & (1 << i)))
39700a
       failed_adevs[i]->hba->ports[failed_adevs[i]->port].command &= ~GRUB_AHCI_HBA_PORT_CMD_FRE;
39700a
@@ -855,6 +859,12 @@ grub_ahci_reset_port (struct grub_ahci_device *dev, int force)
39700a
     {
39700a
       struct grub_disk_ata_pass_through_parms parms2;
39700a
       dev->hba->ports[dev->port].command &= ~GRUB_AHCI_HBA_PORT_CMD_ST;
39700a
+      dev->hba->ports[dev->port].command_issue = 0;
39700a
+      dev->command_list[0].config = 0;
39700a
+      dev->command_table[0].prdt[0].unused = 0;
39700a
+      dev->command_table[0].prdt[0].size = 0;
39700a
+      dev->command_table[0].prdt[0].data_base = 0;
39700a
+
39700a
       endtime = grub_get_time_ms () + 1000;
39700a
       while ((dev->hba->ports[dev->port].command & GRUB_AHCI_HBA_PORT_CMD_CR))
39700a
 	if (grub_get_time_ms () > endtime)
28f7f8
diff --git a/ChangeLog b/ChangeLog
28f7f8
index 9bb18177793..15300b020c6 100644
28f7f8
--- a/ChangeLog
28f7f8
+++ b/ChangeLog
28f7f8
@@ -1,3 +1,7 @@
28f7f8
+2014-01-29  Vladimir Serbinenko  <phcoder@gmail.com>
28f7f8
+
28f7f8
+	* grub-core/disk/ahci.c: Add safety cleanups.
28f7f8
+
28f7f8
 2014-01-29  Vladimir Serbinenko  <phcoder@gmail.com>
28f7f8
 
28f7f8
 	* grub-core/disk/ahci.c: Allocate and clean space for all possible 32