/* Copyright 2017 The Chromium OS Authors. All rights reserved.
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
#ifndef HAL_USB_IMAGE_PROCESSOR_H_
#define HAL_USB_IMAGE_PROCESSOR_H_
#include <camera/CameraMetadata.h>
// FourCC pixel formats (defined as V4L2_PIX_FMT_*).
#include <linux/videodev2.h>
// Declarations of HAL_PIXEL_FORMAT_XXX.
#include <system/graphics.h>
#include "frame_buffer.h"
namespace arc {
// V4L2_PIX_FMT_YVU420(YV12) in ImageProcessor has alignment requirement.
// The stride of Y, U, and V planes should a multiple of 16 pixels.
struct ImageProcessor {
// Calculate the output buffer size when converting to the specified pixel
// format. |fourcc| is defined as V4L2_PIX_FMT_* in linux/videodev2.h.
// Return 0 on error.
static size_t GetConvertedSize(int fourcc, uint32_t width, uint32_t height);
// Return whether this class supports the provided conversion.
static bool SupportsConversion(uint32_t from_fourcc, uint32_t to_fourcc);
// Convert format from |in_frame.fourcc| to |out_frame->fourcc|. Caller should
// fill |data|, |buffer_size|, |width|, and |height| of |out_frame|. The
// function will fill |out_frame->data_size|. Return non-zero error code on
// failure; return 0 on success.
static int ConvertFormat(const android::CameraMetadata& metadata,
const FrameBuffer& in_frame, FrameBuffer* out_frame);
// Scale image size according to |in_frame| and |out_frame|. Only support
// V4L2_PIX_FMT_YUV420 format. Caller should fill |data|, |width|, |height|,
// and |buffer_size| of |out_frame|. The function will fill |data_size| and
// |fourcc| of |out_frame|.
static int Scale(const FrameBuffer& in_frame, FrameBuffer* out_frame);
};
} // namespace arc
#endif // HAL_USB_IMAGE_PROCESSOR_H_