Lines Matching +full:input +full:- +full:pixel +full:- +full:format

10  * SPDX-License-Identifier: Apache-2.0
38 #define LINE_COUNT_HEIGHT (-1)
42 * @brief Video format structure
44 * Used to configure frame format.
47 /** FourCC pixel format value (\ref video_pixel_formats) */
57 * first pixel of a row in order to go to the address of the first pixel of
65 * @brief Video format capability
67 * Used to describe a video endpoint format capability.
70 /** FourCC pixel format value (\ref video_pixel_formats). */
88 * @brief Video format capabilities
93 /** list of video format capabilities (zero terminated). */
101 * of bytes the selected video format's pitch uses, so the video
133 * actually received for input endpoints or to be consumed for output
189 * Used to describe the supported video frame intervals of a given video format.
194 /** video format for which the query is made */
195 const struct video_format *format; member
212 VIDEO_EP_NONE = -1,
213 /** Targets all input or output endpoints of the device */
214 VIDEO_EP_ALL = -2,
215 /** Targets all input endpoints of the device: those consuming data */
216 VIDEO_EP_IN = -3,
218 VIDEO_EP_OUT = -4,
234 * @brief Set video format
243 * @brief Get current video format
270 * @brief List all supported frame intervals of a given format
374 * @brief Set video format.
376 * Configure video device with a specific format.
380 * @param fmt Pointer to a video format struct.
383 * @retval -EINVAL If parameters are invalid.
384 * @retval -ENOTSUP If format is not supported.
385 * @retval -EIO General input / output error.
390 const struct video_driver_api *api = (const struct video_driver_api *)dev->api; in video_set_format()
392 if (api->set_format == NULL) { in video_set_format()
393 return -ENOSYS; in video_set_format()
396 return api->set_format(dev, ep, fmt); in video_set_format()
400 * @brief Get video format.
402 * Get video device current video format.
406 * @param fmt Pointer to video format struct.
408 * @retval pointer to video format
413 const struct video_driver_api *api = (const struct video_driver_api *)dev->api; in video_get_format()
415 if (api->get_format == NULL) { in video_get_format()
416 return -ENOSYS; in video_get_format()
419 return api->get_format(dev, ep, fmt); in video_get_format()
435 * @retval -ENOSYS If API is not implemented.
436 * @retval -EINVAL If parameters are invalid.
437 * @retval -EIO General input / output error.
442 const struct video_driver_api *api = (const struct video_driver_api *)dev->api; in video_set_frmival()
444 if (api->set_frmival == NULL) { in video_set_frmival()
445 return -ENOSYS; in video_set_frmival()
448 return api->set_frmival(dev, ep, frmival); in video_set_frmival()
461 * @retval -ENOSYS If API is not implemented.
462 * @retval -EINVAL If parameters are invalid.
463 * @retval -EIO General input / output error.
468 const struct video_driver_api *api = (const struct video_driver_api *)dev->api; in video_get_frmival()
470 if (api->get_frmival == NULL) { in video_get_frmival()
471 return -ENOSYS; in video_get_frmival()
474 return api->get_frmival(dev, ep, frmival); in video_get_frmival()
480 * List all supported video frame intervals of a given format.
491 * @retval -ENOSYS If API is not implemented.
492 * @retval -EINVAL If parameters are invalid.
493 * @retval -EIO General input / output error.
498 const struct video_driver_api *api = (const struct video_driver_api *)dev->api; in video_enum_frmival()
500 if (api->enum_frmival == NULL) { in video_enum_frmival()
501 return -ENOSYS; in video_enum_frmival()
504 return api->enum_frmival(dev, ep, fie); in video_enum_frmival()
518 * @retval -EINVAL If parameters are invalid.
519 * @retval -EIO General input / output error.
524 const struct video_driver_api *api = (const struct video_driver_api *)dev->api; in video_enqueue()
526 if (api->enqueue == NULL) { in video_enqueue()
527 return -ENOSYS; in video_enqueue()
530 return api->enqueue(dev, ep, buf); in video_enqueue()
545 * @retval -EINVAL If parameters are invalid.
546 * @retval -EIO General input / output error.
551 const struct video_driver_api *api = (const struct video_driver_api *)dev->api; in video_dequeue()
553 if (api->dequeue == NULL) { in video_dequeue()
554 return -ENOSYS; in video_dequeue()
557 return api->dequeue(dev, ep, buf, timeout); in video_dequeue()
572 * @retval 0 Is successful, -ERRNO code otherwise.
576 const struct video_driver_api *api = (const struct video_driver_api *)dev->api; in video_flush()
578 if (api->flush == NULL) { in video_flush()
579 return -ENOSYS; in video_flush()
582 return api->flush(dev, ep, cancel); in video_flush()
595 * @retval -EIO General input / output error.
599 const struct video_driver_api *api = (const struct video_driver_api *)dev->api; in video_stream_start()
601 if (api->stream_start == NULL) { in video_stream_start()
602 return -ENOSYS; in video_stream_start()
605 return api->stream_start(dev); in video_stream_start()
615 * @retval -EIO General input / output error.
619 const struct video_driver_api *api = (const struct video_driver_api *)dev->api; in video_stream_stop()
622 if (api->stream_stop == NULL) { in video_stream_stop()
623 return -ENOSYS; in video_stream_stop()
626 ret = api->stream_stop(dev); in video_stream_stop()
639 * @retval 0 Is successful, -ERRNO code otherwise.
644 const struct video_driver_api *api = (const struct video_driver_api *)dev->api; in video_get_caps()
646 if (api->get_caps == NULL) { in video_get_caps()
647 return -ENOSYS; in video_get_caps()
650 return api->get_caps(dev, ep, caps); in video_get_caps()
664 * @retval -EINVAL If parameters are invalid.
665 * @retval -ENOTSUP If format is not supported.
666 * @retval -EIO General input / output error.
670 const struct video_driver_api *api = (const struct video_driver_api *)dev->api; in video_set_ctrl()
672 if (api->set_ctrl == NULL) { in video_set_ctrl()
673 return -ENOSYS; in video_set_ctrl()
676 return api->set_ctrl(dev, cid, value); in video_set_ctrl()
690 * @retval -EINVAL If parameters are invalid.
691 * @retval -ENOTSUP If format is not supported.
692 * @retval -EIO General input / output error.
696 const struct video_driver_api *api = (const struct video_driver_api *)dev->api; in video_get_ctrl()
698 if (api->get_ctrl == NULL) { in video_get_ctrl()
699 return -ENOSYS; in video_get_ctrl()
702 return api->get_ctrl(dev, cid, value); in video_get_ctrl()
716 * @retval 0 Is successful, -ERRNO code otherwise.
721 const struct video_driver_api *api = (const struct video_driver_api *)dev->api; in video_set_signal()
723 if (api->set_signal == NULL) { in video_set_signal()
724 return -ENOSYS; in video_set_signal()
727 return api->set_signal(dev, ep, signal); in video_set_signal()
759 * @brief Search for a format that matches in a list of capabilities
761 * @param fmts The format capability list to search.
762 * @param fmt The format to find in the list.
763 * @param idx The pointer to a number of the first format that matches.
765 * @return 0 when a format is found.
766 * @return -ENOENT when no matching format is found.
780 return (uint64_t)NSEC_PER_SEC * frmival->numerator / frmival->denominator; in video_frmival_nsec()
799 * - @c match->format to the @ref video_format of interest.
800 * - @c match->type to @ref VIDEO_FRMIVAL_TYPE_DISCRETE.
801 * - @c match->discrete to the desired frame interval.
805 * - @c match->discrete to the value of the closest frame interval.
806 * - @c match->index to the index of the closest frame interval.
815 /* fourcc - four-character-code */
820 * @defgroup video_pixel_formats Video pixel formats
829 /** BGGR8 pixel format */
831 /** GBRG8 pixel format */
833 /** GRBG8 pixel format */
835 /** RGGB8 pixel format */
847 /** RGB565 pixel format */
848 #define VIDEO_PIX_FMT_RGB565 video_fourcc('R', 'G', 'B', 'P') /* 16 RGB-5-6-5 */
850 /** XRGB32 pixel format */
851 #define VIDEO_PIX_FMT_XRGB32 video_fourcc('B', 'X', '2', '4') /* 32 XRGB-8-8-8-8 */
862 /** YUYV pixel format */
863 #define VIDEO_PIX_FMT_YUYV video_fourcc('Y', 'U', 'Y', 'V') /* 16 Y0-Cb0 Y1-Cr0 */
865 /** XYUV32 pixel format */
866 #define VIDEO_PIX_FMT_XYUV32 video_fourcc('X', 'Y', 'U', 'V') /* 32 XYUV-8-8-8-8 */
878 /** JPEG pixel format */
890 * @brief Get number of bytes per pixel of a pixel format
892 * @param pixfmt FourCC pixel format value (\ref video_pixel_formats).