diff options
author | Benjamin Herrenschmidt <benh@kernel.crashing.org> | 2008-04-29 16:57:37 -0400 |
---|---|---|
committer | Bartlomiej Zolnierkiewicz <bzolnier@gmail.com> | 2008-04-29 16:57:37 -0400 |
commit | b26b0c590066f65ff3b1ff438502f3c40ea39520 (patch) | |
tree | bd17faaa4f10748cfde619d80da8e21d0864df60 /drivers/ide | |
parent | 7663c1e2792a9662b23dec6e19bfcd3d55360b8f (diff) |
ide: fix crash at boot with siimage driver
Some change to the IDE layer are causing the siimage driver to crash
at boot with a NULL dereference. This is due to the sil_dma_ops not
containing all the necessary pointers. I suppose it used to just
"override" the defaults while now, it needs to contain everything.
[bart: while at it: sil_dma_ops should be const now (pointed out by Sergei)]
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Cc: Sergei Shtylyov <sshtylyov@ru.mvista.com>,
Signed-off-by: Bartlomiej Zolnierkiewicz <bzolnier@gmail.com>
Diffstat (limited to 'drivers/ide')
-rw-r--r-- | drivers/ide/pci/siimage.c | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/drivers/ide/pci/siimage.c b/drivers/ide/pci/siimage.c index 4cf8fc54aa2a..0006b9e58567 100644 --- a/drivers/ide/pci/siimage.c +++ b/drivers/ide/pci/siimage.c | |||
@@ -737,8 +737,15 @@ static const struct ide_port_ops sil_sata_port_ops = { | |||
737 | .cable_detect = sil_cable_detect, | 737 | .cable_detect = sil_cable_detect, |
738 | }; | 738 | }; |
739 | 739 | ||
740 | static struct ide_dma_ops sil_dma_ops = { | 740 | static const struct ide_dma_ops sil_dma_ops = { |
741 | .dma_host_set = ide_dma_host_set, | ||
742 | .dma_setup = ide_dma_setup, | ||
743 | .dma_exec_cmd = ide_dma_exec_cmd, | ||
744 | .dma_start = ide_dma_start, | ||
745 | .dma_end = __ide_dma_end, | ||
741 | .dma_test_irq = siimage_dma_test_irq, | 746 | .dma_test_irq = siimage_dma_test_irq, |
747 | .dma_timeout = ide_dma_timeout, | ||
748 | .dma_lost_irq = ide_dma_lost_irq, | ||
742 | }; | 749 | }; |
743 | 750 | ||
744 | #define DECLARE_SII_DEV(name_str, p_ops) \ | 751 | #define DECLARE_SII_DEV(name_str, p_ops) \ |