ivtv-udma.h 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. /*
  2. Copyright (C) 2003-2004 Kevin Thayer <nufan_wfk at yahoo.com>
  3. Copyright (C) 2004 Chris Kennedy <c@groovy.org>
  4. Copyright (C) 2006-2007 Hans Verkuil <hverkuil@xs4all.nl>
  5. This program is free software; you can redistribute it and/or modify
  6. it under the terms of the GNU General Public License as published by
  7. the Free Software Foundation; either version 2 of the License, or
  8. (at your option) any later version.
  9. This program is distributed in the hope that it will be useful,
  10. but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. GNU General Public License for more details.
  13. You should have received a copy of the GNU General Public License
  14. along with this program; if not, write to the Free Software
  15. Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
  16. */
  17. /* User DMA functions */
  18. void ivtv_udma_get_page_info(struct ivtv_dma_page_info *dma_page, unsigned long first, unsigned long size);
  19. int ivtv_udma_fill_sg_list(struct ivtv_user_dma *dma, struct ivtv_dma_page_info *dma_page, int map_offset);
  20. void ivtv_udma_fill_sg_array(struct ivtv_user_dma *dma, u32 buffer_offset, u32 buffer_offset_2, u32 split);
  21. int ivtv_udma_setup(struct ivtv *itv, unsigned long ivtv_dest_addr,
  22. void __user *userbuf, int size_in_bytes);
  23. void ivtv_udma_unmap(struct ivtv *itv);
  24. void ivtv_udma_free(struct ivtv *itv);
  25. void ivtv_udma_alloc(struct ivtv *itv);
  26. void ivtv_udma_prepare(struct ivtv *itv);
  27. void ivtv_udma_start(struct ivtv *itv);
  28. static inline void ivtv_udma_sync_for_device(struct ivtv *itv)
  29. {
  30. pci_dma_sync_single_for_device((struct pci_dev *)itv->dev, itv->udma.SG_handle,
  31. sizeof(itv->udma.SGarray), PCI_DMA_TODEVICE);
  32. }
  33. static inline void ivtv_udma_sync_for_cpu(struct ivtv *itv)
  34. {
  35. pci_dma_sync_single_for_cpu((struct pci_dev *)itv->dev, itv->udma.SG_handle,
  36. sizeof(itv->udma.SGarray), PCI_DMA_TODEVICE);
  37. }