Gitweb:     
http://git.kernel.org/git/?p=linux/kernel/git/torvalds/linux-2.6.git;a=commit;h=86865771ea213d756b03e1f2ff44d3f811672762
Commit:     86865771ea213d756b03e1f2ff44d3f811672762
Parent:     7fc67afc436cf7f74d8cc697012696187332fc35
Author:     Michael Ellerman <[EMAIL PROTECTED]>
AuthorDate: Wed Jan 30 01:14:01 2008 +1100
Committer:  Paul Mackerras <[EMAIL PROTECTED]>
CommitDate: Thu Jan 31 12:11:10 2008 +1100

    [POWERPC] Split out the IOMMU logic from cell_dma_dev_setup()
    
    Split the IOMMU logic out from cell_dma_dev_setup() into a separate
    function.  If we're not using dma_direct_ops or dma_iommu_ops we don't
    know what the hell's going on, so BUG.
    
    Signed-off-by: Michael Ellerman <[EMAIL PROTECTED]>
    Acked-by: Arnd Bergmann <[EMAIL PROTECTED]>
    Signed-off-by: Paul Mackerras <[EMAIL PROTECTED]>
---
 arch/powerpc/platforms/cell/iommu.c |   19 +++++++++++++------
 1 files changed, 13 insertions(+), 6 deletions(-)

diff --git a/arch/powerpc/platforms/cell/iommu.c 
b/arch/powerpc/platforms/cell/iommu.c
index b3655aa..a6e6bc1 100644
--- a/arch/powerpc/platforms/cell/iommu.c
+++ b/arch/powerpc/platforms/cell/iommu.c
@@ -507,17 +507,12 @@ static struct cbe_iommu *cell_iommu_for_node(int nid)
 
 static unsigned long cell_dma_direct_offset;
 
-static void cell_dma_dev_setup(struct device *dev)
+static void cell_dma_dev_setup_iommu(struct device *dev)
 {
        struct iommu_window *window;
        struct cbe_iommu *iommu;
        struct dev_archdata *archdata = &dev->archdata;
 
-       if (get_pci_dma_ops() == &dma_direct_ops) {
-               archdata->dma_data = (void *)cell_dma_direct_offset;
-               return;
-       }
-
        /* Current implementation uses the first window available in that
         * node's iommu. We -might- do something smarter later though it may
         * never be necessary
@@ -534,6 +529,18 @@ static void cell_dma_dev_setup(struct device *dev)
        archdata->dma_data = &window->table;
 }
 
+static void cell_dma_dev_setup(struct device *dev)
+{
+       struct dev_archdata *archdata = &dev->archdata;
+
+       if (get_pci_dma_ops() == &dma_iommu_ops)
+               cell_dma_dev_setup_iommu(dev);
+       else if (get_pci_dma_ops() == &dma_direct_ops)
+               archdata->dma_data = (void *)cell_dma_direct_offset;
+       else
+               BUG();
+}
+
 static void cell_pci_dma_dev_setup(struct pci_dev *dev)
 {
        cell_dma_dev_setup(&dev->dev);
-
To unsubscribe from this list: send the line "unsubscribe git-commits-head" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to