| /* SPDX-License-Identifier: GPL-2.0+ */ |
| /* |
| * Copyright (c) 2011-2018 Magewell Electronics Co., Ltd. (Nanjing) |
| * All rights reserved. |
| * Author: Yong Deng <yong.deng@magewell.com> |
| */ |
| |
| #ifndef __SUN6I_CSI_H__ |
| #define __SUN6I_CSI_H__ |
| |
| #include <media/v4l2-device.h> |
| #include <media/v4l2-fwnode.h> |
| #include <media/videobuf2-v4l2.h> |
| |
| #include "sun6i_video.h" |
| |
| #define SUN6I_CSI_NAME "sun6i-csi" |
| #define SUN6I_CSI_DESCRIPTION "Allwinner A31 CSI Device" |
| |
| struct sun6i_csi_buffer { |
| struct vb2_v4l2_buffer v4l2_buffer; |
| struct list_head list; |
| |
| dma_addr_t dma_addr; |
| bool queued_to_csi; |
| }; |
| |
| /** |
| * struct sun6i_csi_config - configs for sun6i csi |
| * @pixelformat: v4l2 pixel format (V4L2_PIX_FMT_*) |
| * @code: media bus format code (MEDIA_BUS_FMT_*) |
| * @field: used interlacing type (enum v4l2_field) |
| * @width: frame width |
| * @height: frame height |
| */ |
| struct sun6i_csi_config { |
| u32 pixelformat; |
| u32 code; |
| u32 field; |
| u32 width; |
| u32 height; |
| }; |
| |
| struct sun6i_csi_v4l2 { |
| struct v4l2_device v4l2_dev; |
| struct media_device media_dev; |
| |
| struct v4l2_async_notifier notifier; |
| /* video port settings */ |
| struct v4l2_fwnode_endpoint v4l2_ep; |
| }; |
| |
| struct sun6i_csi_device { |
| struct device *dev; |
| |
| struct sun6i_csi_config config; |
| struct sun6i_csi_v4l2 v4l2; |
| struct sun6i_video video; |
| |
| struct regmap *regmap; |
| struct clk *clock_mod; |
| struct clk *clock_ram; |
| struct reset_control *reset; |
| |
| int planar_offset[3]; |
| }; |
| |
| struct sun6i_csi_variant { |
| unsigned long clock_mod_rate; |
| }; |
| |
| /** |
| * sun6i_csi_is_format_supported() - check if the format supported by csi |
| * @csi_dev: pointer to the csi device |
| * @pixformat: v4l2 pixel format (V4L2_PIX_FMT_*) |
| * @mbus_code: media bus format code (MEDIA_BUS_FMT_*) |
| * |
| * Return: true if format is supported, false otherwise. |
| */ |
| bool sun6i_csi_is_format_supported(struct sun6i_csi_device *csi_dev, |
| u32 pixformat, u32 mbus_code); |
| |
| /** |
| * sun6i_csi_set_power() - power on/off the csi |
| * @csi_dev: pointer to the csi device |
| * @enable: on/off |
| * |
| * Return: 0 if successful, error code otherwise. |
| */ |
| int sun6i_csi_set_power(struct sun6i_csi_device *csi_dev, bool enable); |
| |
| /** |
| * sun6i_csi_update_config() - update the csi register settings |
| * @csi_dev: pointer to the csi device |
| * @config: see struct sun6i_csi_config |
| * |
| * Return: 0 if successful, error code otherwise. |
| */ |
| int sun6i_csi_update_config(struct sun6i_csi_device *csi_dev, |
| struct sun6i_csi_config *config); |
| |
| /** |
| * sun6i_csi_update_buf_addr() - update the csi frame buffer address |
| * @csi_dev: pointer to the csi device |
| * @addr: frame buffer's physical address |
| */ |
| void sun6i_csi_update_buf_addr(struct sun6i_csi_device *csi_dev, |
| dma_addr_t addr); |
| |
| /** |
| * sun6i_csi_set_stream() - start/stop csi streaming |
| * @csi_dev: pointer to the csi device |
| * @enable: start/stop |
| */ |
| void sun6i_csi_set_stream(struct sun6i_csi_device *csi_dev, bool enable); |
| |
| /* get bpp form v4l2 pixformat */ |
| static inline int sun6i_csi_get_bpp(unsigned int pixformat) |
| { |
| switch (pixformat) { |
| case V4L2_PIX_FMT_SBGGR8: |
| case V4L2_PIX_FMT_SGBRG8: |
| case V4L2_PIX_FMT_SGRBG8: |
| case V4L2_PIX_FMT_SRGGB8: |
| case V4L2_PIX_FMT_JPEG: |
| return 8; |
| case V4L2_PIX_FMT_SBGGR10: |
| case V4L2_PIX_FMT_SGBRG10: |
| case V4L2_PIX_FMT_SGRBG10: |
| case V4L2_PIX_FMT_SRGGB10: |
| return 10; |
| case V4L2_PIX_FMT_SBGGR12: |
| case V4L2_PIX_FMT_SGBRG12: |
| case V4L2_PIX_FMT_SGRBG12: |
| case V4L2_PIX_FMT_SRGGB12: |
| case V4L2_PIX_FMT_NV12_16L16: |
| case V4L2_PIX_FMT_NV12: |
| case V4L2_PIX_FMT_NV21: |
| case V4L2_PIX_FMT_YUV420: |
| case V4L2_PIX_FMT_YVU420: |
| return 12; |
| case V4L2_PIX_FMT_YUYV: |
| case V4L2_PIX_FMT_YVYU: |
| case V4L2_PIX_FMT_UYVY: |
| case V4L2_PIX_FMT_VYUY: |
| case V4L2_PIX_FMT_NV16: |
| case V4L2_PIX_FMT_NV61: |
| case V4L2_PIX_FMT_YUV422P: |
| case V4L2_PIX_FMT_RGB565: |
| case V4L2_PIX_FMT_RGB565X: |
| return 16; |
| case V4L2_PIX_FMT_RGB24: |
| case V4L2_PIX_FMT_BGR24: |
| return 24; |
| case V4L2_PIX_FMT_RGB32: |
| case V4L2_PIX_FMT_BGR32: |
| return 32; |
| default: |
| WARN(1, "Unsupported pixformat: 0x%x\n", pixformat); |
| break; |
| } |
| |
| return 0; |
| } |
| |
| #endif /* __SUN6I_CSI_H__ */ |