vsp1_rwpf.h 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. /*
  2. * vsp1_rwpf.h -- R-Car VSP1 Read and Write Pixel Formatters
  3. *
  4. * Copyright (C) 2013-2014 Renesas Electronics Corporation
  5. *
  6. * Contact: Laurent Pinchart (laurent.pinchart@ideasonboard.com)
  7. *
  8. * This program is free software; you can redistribute it and/or modify
  9. * it under the terms of the GNU General Public License as published by
  10. * the Free Software Foundation; either version 2 of the License, or
  11. * (at your option) any later version.
  12. */
  13. #ifndef __VSP1_RWPF_H__
  14. #define __VSP1_RWPF_H__
  15. #include <media/media-entity.h>
  16. #include <media/v4l2-ctrls.h>
  17. #include <media/v4l2-subdev.h>
  18. #include "vsp1.h"
  19. #include "vsp1_entity.h"
  20. #define RWPF_PAD_SINK 0
  21. #define RWPF_PAD_SOURCE 1
  22. struct v4l2_ctrl;
  23. struct vsp1_dl_manager;
  24. struct vsp1_rwpf;
  25. struct vsp1_video;
  26. struct vsp1_rwpf_memory {
  27. dma_addr_t addr[3];
  28. };
  29. struct vsp1_rwpf {
  30. struct vsp1_entity entity;
  31. struct v4l2_ctrl_handler ctrls;
  32. struct vsp1_video *video;
  33. unsigned int max_width;
  34. unsigned int max_height;
  35. struct v4l2_pix_format_mplane format;
  36. const struct vsp1_format_info *fmtinfo;
  37. unsigned int bru_input;
  38. unsigned int alpha;
  39. unsigned int offsets[2];
  40. struct vsp1_rwpf_memory mem;
  41. struct vsp1_dl_manager *dlm;
  42. };
  43. static inline struct vsp1_rwpf *to_rwpf(struct v4l2_subdev *subdev)
  44. {
  45. return container_of(subdev, struct vsp1_rwpf, entity.subdev);
  46. }
  47. static inline struct vsp1_rwpf *entity_to_rwpf(struct vsp1_entity *entity)
  48. {
  49. return container_of(entity, struct vsp1_rwpf, entity);
  50. }
  51. struct vsp1_rwpf *vsp1_rpf_create(struct vsp1_device *vsp1, unsigned int index);
  52. struct vsp1_rwpf *vsp1_wpf_create(struct vsp1_device *vsp1, unsigned int index);
  53. int vsp1_rwpf_init_ctrls(struct vsp1_rwpf *rwpf);
  54. int vsp1_rwpf_enum_mbus_code(struct v4l2_subdev *subdev,
  55. struct v4l2_subdev_pad_config *cfg,
  56. struct v4l2_subdev_mbus_code_enum *code);
  57. int vsp1_rwpf_enum_frame_size(struct v4l2_subdev *subdev,
  58. struct v4l2_subdev_pad_config *cfg,
  59. struct v4l2_subdev_frame_size_enum *fse);
  60. int vsp1_rwpf_get_format(struct v4l2_subdev *subdev,
  61. struct v4l2_subdev_pad_config *cfg,
  62. struct v4l2_subdev_format *fmt);
  63. int vsp1_rwpf_set_format(struct v4l2_subdev *subdev,
  64. struct v4l2_subdev_pad_config *cfg,
  65. struct v4l2_subdev_format *fmt);
  66. int vsp1_rwpf_get_selection(struct v4l2_subdev *subdev,
  67. struct v4l2_subdev_pad_config *cfg,
  68. struct v4l2_subdev_selection *sel);
  69. int vsp1_rwpf_set_selection(struct v4l2_subdev *subdev,
  70. struct v4l2_subdev_pad_config *cfg,
  71. struct v4l2_subdev_selection *sel);
  72. struct v4l2_rect *vsp1_rwpf_get_crop(struct vsp1_rwpf *rwpf,
  73. struct v4l2_subdev_pad_config *config);
  74. /**
  75. * vsp1_rwpf_set_memory - Configure DMA addresses for a [RW]PF
  76. * @rwpf: the [RW]PF instance
  77. *
  78. * This function applies the cached memory buffer address to the hardware.
  79. */
  80. static inline void vsp1_rwpf_set_memory(struct vsp1_rwpf *rwpf)
  81. {
  82. rwpf->entity.ops->set_memory(&rwpf->entity);
  83. }
  84. #endif /* __VSP1_RWPF_H__ */