summaryrefslogtreecommitdiff
path: root/ANDROID_3.4.5/arch/alpha/kernel/pci_impl.h
diff options
context:
space:
mode:
Diffstat (limited to 'ANDROID_3.4.5/arch/alpha/kernel/pci_impl.h')
-rw-r--r--ANDROID_3.4.5/arch/alpha/kernel/pci_impl.h201
1 files changed, 0 insertions, 201 deletions
diff --git a/ANDROID_3.4.5/arch/alpha/kernel/pci_impl.h b/ANDROID_3.4.5/arch/alpha/kernel/pci_impl.h
deleted file mode 100644
index 2b0ac429..00000000
--- a/ANDROID_3.4.5/arch/alpha/kernel/pci_impl.h
+++ /dev/null
@@ -1,201 +0,0 @@
-/*
- * linux/arch/alpha/kernel/pci_impl.h
- *
- * This file contains declarations and inline functions for interfacing
- * with the PCI initialization routines.
- */
-
-struct pci_dev;
-struct pci_controller;
-struct pci_iommu_arena;
-
-/*
- * We can't just blindly use 64K for machines with EISA busses; they
- * may also have PCI-PCI bridges present, and then we'd configure the
- * bridge incorrectly.
- *
- * Also, we start at 0x8000 or 0x9000, in hopes to get all devices'
- * IO space areas allocated *before* 0xC000; this is because certain
- * BIOSes (Millennium for one) use PCI Config space "mechanism #2"
- * accesses to probe the bus. If a device's registers appear at 0xC000,
- * it may see an INx/OUTx at that address during BIOS emulation of the
- * VGA BIOS, and some cards, notably Adaptec 2940UW, take mortal offense.
- */
-
-#define EISA_DEFAULT_IO_BASE 0x9000 /* start above 8th slot */
-#define DEFAULT_IO_BASE 0x8000 /* start at 8th slot */
-
-/*
- * We try to make the DEFAULT_MEM_BASE addresses *always* have more than
- * a single bit set. This is so that devices like the broken Myrinet card
- * will always have a PCI memory address that will never match a IDSEL
- * address in PCI Config space, which can cause problems with early rev cards.
- */
-
-/*
- * An XL is AVANTI (APECS) family, *but* it has only 27 bits of ISA address
- * that get passed through the PCI<->ISA bridge chip. Although this causes
- * us to set the PCI->Mem window bases lower than normal, we still allocate
- * PCI bus devices' memory addresses *below* the low DMA mapping window,
- * and hope they fit below 64Mb (to avoid conflicts), and so that they can
- * be accessed via SPARSE space.
- *
- * We accept the risk that a broken Myrinet card will be put into a true XL
- * and thus can more easily run into the problem described below.
- */
-#define XL_DEFAULT_MEM_BASE ((16+2)*1024*1024) /* 16M to 64M-1 is avail */
-
-/*
- * APECS and LCA have only 34 bits for physical addresses, thus limiting PCI
- * bus memory addresses for SPARSE access to be less than 128Mb.
- */
-#define APECS_AND_LCA_DEFAULT_MEM_BASE ((16+2)*1024*1024)
-
-/*
- * Because MCPCIA and T2 core logic support more bits for
- * physical addresses, they should allow an expanded range of SPARSE
- * memory addresses. However, we do not use them all, in order to
- * avoid the HAE manipulation that would be needed.
- */
-#define MCPCIA_DEFAULT_MEM_BASE ((32+2)*1024*1024)
-#define T2_DEFAULT_MEM_BASE ((16+1)*1024*1024)
-
-/*
- * Because CIA and PYXIS have more bits for physical addresses,
- * they support an expanded range of SPARSE memory addresses.
- */
-#define DEFAULT_MEM_BASE ((128+16)*1024*1024)
-
-/* ??? Experimenting with no HAE for CIA. */
-#define CIA_DEFAULT_MEM_BASE ((32+2)*1024*1024)
-
-#define IRONGATE_DEFAULT_MEM_BASE ((256*8-16)*1024*1024)
-
-#define DEFAULT_AGP_APER_SIZE (64*1024*1024)
-
-/*
- * A small note about bridges and interrupts. The DECchip 21050 (and
- * later) adheres to the PCI-PCI bridge specification. This says that
- * the interrupts on the other side of a bridge are swizzled in the
- * following manner:
- *
- * Dev Interrupt Interrupt
- * Pin on Pin on
- * Device Connector
- *
- * 4 A A
- * B B
- * C C
- * D D
- *
- * 5 A B
- * B C
- * C D
- * D A
- *
- * 6 A C
- * B D
- * C A
- * D B
- *
- * 7 A D
- * B A
- * C B
- * D C
- *
- * Where A = pin 1, B = pin 2 and so on and pin=0 = default = A.
- * Thus, each swizzle is ((pin-1) + (device#-4)) % 4
- *
- * pci_swizzle_interrupt_pin() swizzles for exactly one bridge. The routine
- * pci_common_swizzle() handles multiple bridges. But there are a
- * couple boards that do strange things.
- */
-
-
-/* The following macro is used to implement the table-based irq mapping
- function for all single-bus Alphas. */
-
-#define COMMON_TABLE_LOOKUP \
-({ long _ctl_ = -1; \
- if (slot >= min_idsel && slot <= max_idsel && pin < irqs_per_slot) \
- _ctl_ = irq_tab[slot - min_idsel][pin]; \
- _ctl_; })
-
-
-/* A PCI IOMMU allocation arena. There are typically two of these
- regions per bus. */
-/* ??? The 8400 has a 32-byte pte entry, and the entire table apparently
- lives directly on the host bridge (no tlb?). We don't support this
- machine, but if we ever did, we'd need to parameterize all this quite
- a bit further. Probably with per-bus operation tables. */
-
-struct pci_iommu_arena
-{
- spinlock_t lock;
- struct pci_controller *hose;
-#define IOMMU_INVALID_PTE 0x2 /* 32:63 bits MBZ */
-#define IOMMU_RESERVED_PTE 0xface
- unsigned long *ptes;
- dma_addr_t dma_base;
- unsigned int size;
- unsigned int next_entry;
- unsigned int align_entry;
-};
-
-#if defined(CONFIG_ALPHA_SRM) && \
- (defined(CONFIG_ALPHA_CIA) || defined(CONFIG_ALPHA_LCA))
-# define NEED_SRM_SAVE_RESTORE
-#else
-# undef NEED_SRM_SAVE_RESTORE
-#endif
-
-#if defined(CONFIG_ALPHA_GENERIC) || defined(NEED_SRM_SAVE_RESTORE)
-# define ALPHA_RESTORE_SRM_SETUP
-#else
-# undef ALPHA_RESTORE_SRM_SETUP
-#endif
-
-#ifdef ALPHA_RESTORE_SRM_SETUP
-/* Store PCI device configuration left by SRM here. */
-struct pdev_srm_saved_conf
-{
- struct pdev_srm_saved_conf *next;
- struct pci_dev *dev;
-};
-
-extern void pci_restore_srm_config(void);
-#else
-#define pdev_save_srm_config(dev) do {} while (0)
-#define pci_restore_srm_config() do {} while (0)
-#endif
-
-/* The hose list. */
-extern struct pci_controller *hose_head, **hose_tail;
-extern struct pci_controller *pci_isa_hose;
-
-extern unsigned long alpha_agpgart_size;
-
-extern void common_init_pci(void);
-#define common_swizzle pci_common_swizzle
-extern struct pci_controller *alloc_pci_controller(void);
-extern struct resource *alloc_resource(void);
-
-extern struct pci_iommu_arena *iommu_arena_new_node(int,
- struct pci_controller *,
- dma_addr_t, unsigned long,
- unsigned long);
-extern struct pci_iommu_arena *iommu_arena_new(struct pci_controller *,
- dma_addr_t, unsigned long,
- unsigned long);
-extern const char *const pci_io_names[];
-extern const char *const pci_mem_names[];
-extern const char pci_hae0_name[];
-
-extern unsigned long size_for_memory(unsigned long max);
-
-extern int iommu_reserve(struct pci_iommu_arena *, long, long);
-extern int iommu_release(struct pci_iommu_arena *, long, long);
-extern int iommu_bind(struct pci_iommu_arena *, long, long, struct page **);
-extern int iommu_unbind(struct pci_iommu_arena *, long, long);
-
-