H64846 s 00052/00000/00000 d D 1.1 02/03/13 20:31:03 patch 2 1 cC cF1 cK34273 cO-rw-rw-r-- e s 00000/00000/00000 d D 1.0 02/03/13 20:31:03 patch 1 0 c BitKeeper file /home/marcelo/bk/linux-2.4/arch/mips/hp-lj/pci-dma.c cBtorvalds@athlon.transmeta.com|ChangeSet|20020205173056|16047|c1d11a41ed024864 cHplucky.distro.conectiva cK32279 cParch/mips/hp-lj/pci-dma.c cRa0f291512414d86 cV4 cX0x821 cZ-03:00 e u U f e 0 f x 0x821 t T I 2 /* * Copyright (C) 2000 Ani Joshi * * * Dynamic DMA mapping support. * * swiped from i386, and cloned for MIPS by Geert. * */ #include #include #include #include #include void *pci_alloc_consistent(struct pci_dev *hwdev, size_t size, dma_addr_t *dma_handle) { void *ret; int gfp = GFP_ATOMIC; if (hwdev == NULL || hwdev->dma_mask != 0xffffffff) gfp |= GFP_DMA; ret = (void *)__get_free_pages(gfp, get_order(size)); if (ret != NULL) { memset(ret, 0, size); *dma_handle = virt_to_bus(ret); // REVISIT this needs reviewal as mentioned in bug report // currently we bump kseg0 allocates to kseg1 uncacheable space if ((((unsigned int) ret) & 0xe0000000) == 0x80000000) { //flush the cache to eliminate coherency problems // and assure dirty lines won't later get written over any dma, etc. flush_cache_all(); ret = (void*)((unsigned int)ret | 0x20000000); } } return ret; } void pci_free_consistent(struct pci_dev *hwdev, size_t size, void *vaddr, dma_addr_t dma_handle) { free_pages((unsigned long)vaddr, get_order(size)); } E 2 I 1 E 1