dma-dreamcast.c 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. /*
  2. * arch/sh/pci/dma-dreamcast.c
  3. *
  4. * PCI DMA support for the Sega Dreamcast
  5. *
  6. * Copyright (C) 2001, 2002 M. R. Brown
  7. * Copyright (C) 2002, 2003 Paul Mundt
  8. *
  9. * This file originally bore the message (with enclosed-$):
  10. * Id: pci.c,v 1.3 2003/05/04 19:29:46 lethal Exp
  11. * Dreamcast PCI: Supports SEGA Broadband Adaptor only.
  12. *
  13. * This file is subject to the terms and conditions of the GNU General Public
  14. * License. See the file "COPYING" in the main directory of this archive
  15. * for more details.
  16. */
  17. #include <linux/config.h>
  18. #include <linux/sched.h>
  19. #include <linux/kernel.h>
  20. #include <linux/param.h>
  21. #include <linux/interrupt.h>
  22. #include <linux/init.h>
  23. #include <linux/irq.h>
  24. #include <linux/pci.h>
  25. #include <linux/dma-mapping.h>
  26. #include <linux/device.h>
  27. #include <asm/io.h>
  28. #include <asm/irq.h>
  29. #include <asm/mach/pci.h>
  30. static int gapspci_dma_used = 0;
  31. void *dreamcast_consistent_alloc(struct device *dev, size_t size,
  32. dma_addr_t *dma_handle, int flag)
  33. {
  34. unsigned long buf;
  35. if (dev && dev->bus != &pci_bus_type)
  36. return NULL;
  37. if (gapspci_dma_used + size > GAPSPCI_DMA_SIZE)
  38. return ERR_PTR(-EINVAL);
  39. buf = GAPSPCI_DMA_BASE + gapspci_dma_used;
  40. gapspci_dma_used = PAGE_ALIGN(gapspci_dma_used+size);
  41. *dma_handle = (dma_addr_t)buf;
  42. buf = P2SEGADDR(buf);
  43. /* Flush the dcache before we hand off the buffer */
  44. dma_cache_wback_inv((void *)buf, size);
  45. return (void *)buf;
  46. }
  47. int dreamcast_consistent_free(struct device *dev, size_t size,
  48. void *vaddr, dma_addr_t dma_handle)
  49. {
  50. if (dev && dev->bus != &pci_bus_type)
  51. return -EINVAL;
  52. /* XXX */
  53. gapspci_dma_used = 0;
  54. return 0;
  55. }