162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */ 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * camss-ispif.h 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Qualcomm MSM Camera Subsystem - ISPIF (ISP Interface) Module 662306a36Sopenharmony_ci * 762306a36Sopenharmony_ci * Copyright (c) 2013-2014, The Linux Foundation. All rights reserved. 862306a36Sopenharmony_ci * Copyright (C) 2015-2018 Linaro Ltd. 962306a36Sopenharmony_ci */ 1062306a36Sopenharmony_ci#ifndef QC_MSM_CAMSS_ISPIF_H 1162306a36Sopenharmony_ci#define QC_MSM_CAMSS_ISPIF_H 1262306a36Sopenharmony_ci 1362306a36Sopenharmony_ci#include <linux/clk.h> 1462306a36Sopenharmony_ci#include <media/media-entity.h> 1562306a36Sopenharmony_ci#include <media/v4l2-device.h> 1662306a36Sopenharmony_ci#include <media/v4l2-subdev.h> 1762306a36Sopenharmony_ci 1862306a36Sopenharmony_ci#define MSM_ISPIF_PAD_SINK 0 1962306a36Sopenharmony_ci#define MSM_ISPIF_PAD_SRC 1 2062306a36Sopenharmony_ci#define MSM_ISPIF_PADS_NUM 2 2162306a36Sopenharmony_ci 2262306a36Sopenharmony_ci#define MSM_ISPIF_VFE_NUM 2 2362306a36Sopenharmony_ci 2462306a36Sopenharmony_cienum ispif_intf { 2562306a36Sopenharmony_ci PIX0, 2662306a36Sopenharmony_ci RDI0, 2762306a36Sopenharmony_ci PIX1, 2862306a36Sopenharmony_ci RDI1, 2962306a36Sopenharmony_ci RDI2 3062306a36Sopenharmony_ci}; 3162306a36Sopenharmony_ci 3262306a36Sopenharmony_cistruct ispif_intf_cmd_reg { 3362306a36Sopenharmony_ci u32 cmd_0; 3462306a36Sopenharmony_ci u32 cmd_1; 3562306a36Sopenharmony_ci}; 3662306a36Sopenharmony_ci 3762306a36Sopenharmony_cistruct ispif_line { 3862306a36Sopenharmony_ci struct ispif_device *ispif; 3962306a36Sopenharmony_ci u8 id; 4062306a36Sopenharmony_ci u8 csid_id; 4162306a36Sopenharmony_ci u8 vfe_id; 4262306a36Sopenharmony_ci enum ispif_intf interface; 4362306a36Sopenharmony_ci struct v4l2_subdev subdev; 4462306a36Sopenharmony_ci struct media_pad pads[MSM_ISPIF_PADS_NUM]; 4562306a36Sopenharmony_ci struct v4l2_mbus_framefmt fmt[MSM_ISPIF_PADS_NUM]; 4662306a36Sopenharmony_ci const u32 *formats; 4762306a36Sopenharmony_ci unsigned int nformats; 4862306a36Sopenharmony_ci}; 4962306a36Sopenharmony_ci 5062306a36Sopenharmony_cistruct ispif_device { 5162306a36Sopenharmony_ci void __iomem *base; 5262306a36Sopenharmony_ci void __iomem *base_clk_mux; 5362306a36Sopenharmony_ci u32 irq; 5462306a36Sopenharmony_ci char irq_name[30]; 5562306a36Sopenharmony_ci struct camss_clock *clock; 5662306a36Sopenharmony_ci int nclocks; 5762306a36Sopenharmony_ci struct camss_clock *clock_for_reset; 5862306a36Sopenharmony_ci int nclocks_for_reset; 5962306a36Sopenharmony_ci struct completion reset_complete[MSM_ISPIF_VFE_NUM]; 6062306a36Sopenharmony_ci int power_count; 6162306a36Sopenharmony_ci struct mutex power_lock; 6262306a36Sopenharmony_ci struct ispif_intf_cmd_reg intf_cmd[MSM_ISPIF_VFE_NUM]; 6362306a36Sopenharmony_ci struct mutex config_lock; 6462306a36Sopenharmony_ci unsigned int line_num; 6562306a36Sopenharmony_ci struct ispif_line *line; 6662306a36Sopenharmony_ci struct camss *camss; 6762306a36Sopenharmony_ci}; 6862306a36Sopenharmony_ci 6962306a36Sopenharmony_cistruct resources_ispif; 7062306a36Sopenharmony_ci 7162306a36Sopenharmony_ciint msm_ispif_subdev_init(struct camss *camss, 7262306a36Sopenharmony_ci const struct resources_ispif *res); 7362306a36Sopenharmony_ci 7462306a36Sopenharmony_ciint msm_ispif_register_entities(struct ispif_device *ispif, 7562306a36Sopenharmony_ci struct v4l2_device *v4l2_dev); 7662306a36Sopenharmony_ci 7762306a36Sopenharmony_civoid msm_ispif_unregister_entities(struct ispif_device *ispif); 7862306a36Sopenharmony_ci 7962306a36Sopenharmony_ci#endif /* QC_MSM_CAMSS_ISPIF_H */ 80