cx18-queue.h 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. /*
  2. * cx18 buffer queues
  3. *
  4. * Derived from ivtv-queue.h
  5. *
  6. * Copyright (C) 2007 Hans Verkuil <hverkuil@xs4all.nl>
  7. * Copyright (C) 2008 Andy Walls <awalls@md.metrocast.net>
  8. *
  9. * This program is free software; you can redistribute it and/or modify
  10. * it under the terms of the GNU General Public License as published by
  11. * the Free Software Foundation; either version 2 of the License, or
  12. * (at your option) any later version.
  13. *
  14. * This program is distributed in the hope that it will be useful,
  15. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  16. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  17. * GNU General Public License for more details.
  18. */
  19. #define CX18_DMA_UNMAPPED ((u32) -1)
  20. /* cx18_buffer utility functions */
  21. static inline void cx18_buf_sync_for_cpu(struct cx18_stream *s,
  22. struct cx18_buffer *buf)
  23. {
  24. pci_dma_sync_single_for_cpu(s->cx->pci_dev, buf->dma_handle,
  25. s->buf_size, s->dma);
  26. }
  27. static inline void cx18_buf_sync_for_device(struct cx18_stream *s,
  28. struct cx18_buffer *buf)
  29. {
  30. pci_dma_sync_single_for_device(s->cx->pci_dev, buf->dma_handle,
  31. s->buf_size, s->dma);
  32. }
  33. void _cx18_mdl_sync_for_device(struct cx18_stream *s, struct cx18_mdl *mdl);
  34. static inline void cx18_mdl_sync_for_device(struct cx18_stream *s,
  35. struct cx18_mdl *mdl)
  36. {
  37. if (list_is_singular(&mdl->buf_list))
  38. cx18_buf_sync_for_device(s, list_first_entry(&mdl->buf_list,
  39. struct cx18_buffer,
  40. list));
  41. else
  42. _cx18_mdl_sync_for_device(s, mdl);
  43. }
  44. void cx18_buf_swap(struct cx18_buffer *buf);
  45. void _cx18_mdl_swap(struct cx18_mdl *mdl);
  46. static inline void cx18_mdl_swap(struct cx18_mdl *mdl)
  47. {
  48. if (list_is_singular(&mdl->buf_list))
  49. cx18_buf_swap(list_first_entry(&mdl->buf_list,
  50. struct cx18_buffer, list));
  51. else
  52. _cx18_mdl_swap(mdl);
  53. }
  54. /* cx18_queue utility functions */
  55. struct cx18_queue *_cx18_enqueue(struct cx18_stream *s, struct cx18_mdl *mdl,
  56. struct cx18_queue *q, int to_front);
  57. static inline
  58. struct cx18_queue *cx18_enqueue(struct cx18_stream *s, struct cx18_mdl *mdl,
  59. struct cx18_queue *q)
  60. {
  61. return _cx18_enqueue(s, mdl, q, 0); /* FIFO */
  62. }
  63. static inline
  64. struct cx18_queue *cx18_push(struct cx18_stream *s, struct cx18_mdl *mdl,
  65. struct cx18_queue *q)
  66. {
  67. return _cx18_enqueue(s, mdl, q, 1); /* LIFO */
  68. }
  69. void cx18_queue_init(struct cx18_queue *q);
  70. struct cx18_mdl *cx18_dequeue(struct cx18_stream *s, struct cx18_queue *q);
  71. struct cx18_mdl *cx18_queue_get_mdl(struct cx18_stream *s, u32 id,
  72. u32 bytesused);
  73. void cx18_flush_queues(struct cx18_stream *s);
  74. /* queue MDL reconfiguration helpers */
  75. void cx18_unload_queues(struct cx18_stream *s);
  76. void cx18_load_queues(struct cx18_stream *s);
  77. /* cx18_stream utility functions */
  78. int cx18_stream_alloc(struct cx18_stream *s);
  79. void cx18_stream_free(struct cx18_stream *s);