|  | @@ -807,3 +807,156 @@ marvel_ioread8(void __iomem *xaddr)
 | 
											
												
													
														|  |  	else if (__marvel_is_port_rtc(addr))
 |  |  	else if (__marvel_is_port_rtc(addr))
 | 
											
												
													
														|  |  		return __marvel_rtc_io(0, addr, 0);
 |  |  		return __marvel_rtc_io(0, addr, 0);
 | 
											
												
													
														|  |  	else if (marvel_is_ioaddr(addr))
 |  |  	else if (marvel_is_ioaddr(addr))
 | 
											
												
													
														|  | 
 |  | +		return __kernel_ldbu(*(vucp)addr);
 | 
											
												
													
														|  | 
 |  | +	else
 | 
											
												
													
														|  | 
 |  | +		/* this should catch other legacy addresses
 | 
											
												
													
														|  | 
 |  | +		   that would normally fail on MARVEL,
 | 
											
												
													
														|  | 
 |  | +		   because there really is nothing there...
 | 
											
												
													
														|  | 
 |  | +		*/
 | 
											
												
													
														|  | 
 |  | +		return ~0;
 | 
											
												
													
														|  | 
 |  | +}
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +void
 | 
											
												
													
														|  | 
 |  | +marvel_iowrite8(u8 b, void __iomem *xaddr)
 | 
											
												
													
														|  | 
 |  | +{
 | 
											
												
													
														|  | 
 |  | +	unsigned long addr = (unsigned long) xaddr;
 | 
											
												
													
														|  | 
 |  | +	if (__marvel_is_port_kbd(addr))
 | 
											
												
													
														|  | 
 |  | +		return;
 | 
											
												
													
														|  | 
 |  | +	else if (__marvel_is_port_rtc(addr)) 
 | 
											
												
													
														|  | 
 |  | +		__marvel_rtc_io(b, addr, 1);
 | 
											
												
													
														|  | 
 |  | +	else if (marvel_is_ioaddr(addr))
 | 
											
												
													
														|  | 
 |  | +		__kernel_stb(b, *(vucp)addr);
 | 
											
												
													
														|  | 
 |  | +}
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +#ifndef CONFIG_ALPHA_GENERIC
 | 
											
												
													
														|  | 
 |  | +EXPORT_SYMBOL(marvel_ioremap);
 | 
											
												
													
														|  | 
 |  | +EXPORT_SYMBOL(marvel_iounmap);
 | 
											
												
													
														|  | 
 |  | +EXPORT_SYMBOL(marvel_is_mmio);
 | 
											
												
													
														|  | 
 |  | +EXPORT_SYMBOL(marvel_ioportmap);
 | 
											
												
													
														|  | 
 |  | +EXPORT_SYMBOL(marvel_ioread8);
 | 
											
												
													
														|  | 
 |  | +EXPORT_SYMBOL(marvel_iowrite8);
 | 
											
												
													
														|  | 
 |  | +#endif
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +/*
 | 
											
												
													
														|  | 
 |  | + * NUMA Support
 | 
											
												
													
														|  | 
 |  | + */
 | 
											
												
													
														|  | 
 |  | +/**********
 | 
											
												
													
														|  | 
 |  | + * FIXME - for now each cpu is a node by itself 
 | 
											
												
													
														|  | 
 |  | + *              -- no real support for striped mode 
 | 
											
												
													
														|  | 
 |  | + **********
 | 
											
												
													
														|  | 
 |  | + */
 | 
											
												
													
														|  | 
 |  | +int
 | 
											
												
													
														|  | 
 |  | +marvel_pa_to_nid(unsigned long pa)
 | 
											
												
													
														|  | 
 |  | +{
 | 
											
												
													
														|  | 
 |  | +	int cpuid;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	if ((pa >> 43) & 1) 	/* I/O */ 
 | 
											
												
													
														|  | 
 |  | +		cpuid = (~(pa >> 35) & 0xff);
 | 
											
												
													
														|  | 
 |  | +	else			/* mem */
 | 
											
												
													
														|  | 
 |  | +		cpuid = ((pa >> 34) & 0x3) | ((pa >> (37 - 2)) & (0x1f << 2));
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	return marvel_cpuid_to_nid(cpuid);
 | 
											
												
													
														|  | 
 |  | +}
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +int
 | 
											
												
													
														|  | 
 |  | +marvel_cpuid_to_nid(int cpuid)
 | 
											
												
													
														|  | 
 |  | +{
 | 
											
												
													
														|  | 
 |  | +	return cpuid;
 | 
											
												
													
														|  | 
 |  | +}
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +unsigned long
 | 
											
												
													
														|  | 
 |  | +marvel_node_mem_start(int nid)
 | 
											
												
													
														|  | 
 |  | +{
 | 
											
												
													
														|  | 
 |  | +	unsigned long pa;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	pa = (nid & 0x3) | ((nid & (0x1f << 2)) << 1);
 | 
											
												
													
														|  | 
 |  | +	pa <<= 34;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	return pa;
 | 
											
												
													
														|  | 
 |  | +}
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +unsigned long
 | 
											
												
													
														|  | 
 |  | +marvel_node_mem_size(int nid)
 | 
											
												
													
														|  | 
 |  | +{
 | 
											
												
													
														|  | 
 |  | +	return 16UL * 1024 * 1024 * 1024; /* 16GB */
 | 
											
												
													
														|  | 
 |  | +}
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +/* 
 | 
											
												
													
														|  | 
 |  | + * AGP GART Support.
 | 
											
												
													
														|  | 
 |  | + */
 | 
											
												
													
														|  | 
 |  | +#include <linux/agp_backend.h>
 | 
											
												
													
														|  | 
 |  | +#include <asm/agp_backend.h>
 | 
											
												
													
														|  | 
 |  | +#include <linux/slab.h>
 | 
											
												
													
														|  | 
 |  | +#include <linux/delay.h>
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +struct marvel_agp_aperture {
 | 
											
												
													
														|  | 
 |  | +	struct pci_iommu_arena *arena;
 | 
											
												
													
														|  | 
 |  | +	long pg_start;
 | 
											
												
													
														|  | 
 |  | +	long pg_count;
 | 
											
												
													
														|  | 
 |  | +};
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +static int
 | 
											
												
													
														|  | 
 |  | +marvel_agp_setup(alpha_agp_info *agp)
 | 
											
												
													
														|  | 
 |  | +{
 | 
											
												
													
														|  | 
 |  | +	struct marvel_agp_aperture *aper;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	if (!alpha_agpgart_size)
 | 
											
												
													
														|  | 
 |  | +		return -ENOMEM;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	aper = kmalloc(sizeof(*aper), GFP_KERNEL);
 | 
											
												
													
														|  | 
 |  | +	if (aper == NULL) return -ENOMEM;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	aper->arena = agp->hose->sg_pci;
 | 
											
												
													
														|  | 
 |  | +	aper->pg_count = alpha_agpgart_size / PAGE_SIZE;
 | 
											
												
													
														|  | 
 |  | +	aper->pg_start = iommu_reserve(aper->arena, aper->pg_count,
 | 
											
												
													
														|  | 
 |  | +				       aper->pg_count - 1);
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	if (aper->pg_start < 0) {
 | 
											
												
													
														|  | 
 |  | +		printk(KERN_ERR "Failed to reserve AGP memory\n");
 | 
											
												
													
														|  | 
 |  | +		kfree(aper);
 | 
											
												
													
														|  | 
 |  | +		return -ENOMEM;
 | 
											
												
													
														|  | 
 |  | +	}
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	agp->aperture.bus_base = 
 | 
											
												
													
														|  | 
 |  | +		aper->arena->dma_base + aper->pg_start * PAGE_SIZE;
 | 
											
												
													
														|  | 
 |  | +	agp->aperture.size = aper->pg_count * PAGE_SIZE;
 | 
											
												
													
														|  | 
 |  | +	agp->aperture.sysdata = aper;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	return 0;
 | 
											
												
													
														|  | 
 |  | +}
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +static void
 | 
											
												
													
														|  | 
 |  | +marvel_agp_cleanup(alpha_agp_info *agp)
 | 
											
												
													
														|  | 
 |  | +{
 | 
											
												
													
														|  | 
 |  | +	struct marvel_agp_aperture *aper = agp->aperture.sysdata;
 | 
											
												
													
														|  | 
 |  | +	int status;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	status = iommu_release(aper->arena, aper->pg_start, aper->pg_count);
 | 
											
												
													
														|  | 
 |  | +	if (status == -EBUSY) {
 | 
											
												
													
														|  | 
 |  | +		printk(KERN_WARNING
 | 
											
												
													
														|  | 
 |  | +		       "Attempted to release bound AGP memory - unbinding\n");
 | 
											
												
													
														|  | 
 |  | +		iommu_unbind(aper->arena, aper->pg_start, aper->pg_count);
 | 
											
												
													
														|  | 
 |  | +		status = iommu_release(aper->arena, aper->pg_start, 
 | 
											
												
													
														|  | 
 |  | +				       aper->pg_count);
 | 
											
												
													
														|  | 
 |  | +	}
 | 
											
												
													
														|  | 
 |  | +	if (status < 0)
 | 
											
												
													
														|  | 
 |  | +		printk(KERN_ERR "Failed to release AGP memory\n");
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	kfree(aper);
 | 
											
												
													
														|  | 
 |  | +	kfree(agp);
 | 
											
												
													
														|  | 
 |  | +}
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +static int
 | 
											
												
													
														|  | 
 |  | +marvel_agp_configure(alpha_agp_info *agp)
 | 
											
												
													
														|  | 
 |  | +{
 | 
											
												
													
														|  | 
 |  | +	io7_ioport_csrs *csrs = ((struct io7_port *)agp->hose->sysdata)->csrs;
 | 
											
												
													
														|  | 
 |  | +	struct io7 *io7 = ((struct io7_port *)agp->hose->sysdata)->io7;
 | 
											
												
													
														|  | 
 |  | +	unsigned int new_rate = 0;
 | 
											
												
													
														|  | 
 |  | +	unsigned long agp_pll;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	/*
 | 
											
												
													
														|  | 
 |  | +	 * Check the requested mode against the PLL setting.
 | 
											
												
													
														|  | 
 |  | +	 * The agpgart_be code has not programmed the card yet,
 | 
											
												
													
														|  | 
 |  | +	 * so we can still tweak mode here.
 | 
											
												
													
														|  | 
 |  | +	 */
 |