162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */ 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * camss-csiphy.h 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Qualcomm MSM Camera Subsystem - CSIPHY Module 662306a36Sopenharmony_ci * 762306a36Sopenharmony_ci * Copyright (c) 2011-2015, The Linux Foundation. All rights reserved. 862306a36Sopenharmony_ci * Copyright (C) 2016-2018 Linaro Ltd. 962306a36Sopenharmony_ci */ 1062306a36Sopenharmony_ci#ifndef QC_MSM_CAMSS_CSIPHY_H 1162306a36Sopenharmony_ci#define QC_MSM_CAMSS_CSIPHY_H 1262306a36Sopenharmony_ci 1362306a36Sopenharmony_ci#include <linux/clk.h> 1462306a36Sopenharmony_ci#include <linux/interrupt.h> 1562306a36Sopenharmony_ci#include <media/media-entity.h> 1662306a36Sopenharmony_ci#include <media/v4l2-device.h> 1762306a36Sopenharmony_ci#include <media/v4l2-mediabus.h> 1862306a36Sopenharmony_ci#include <media/v4l2-subdev.h> 1962306a36Sopenharmony_ci 2062306a36Sopenharmony_ci#define MSM_CSIPHY_PAD_SINK 0 2162306a36Sopenharmony_ci#define MSM_CSIPHY_PAD_SRC 1 2262306a36Sopenharmony_ci#define MSM_CSIPHY_PADS_NUM 2 2362306a36Sopenharmony_ci 2462306a36Sopenharmony_cistruct csiphy_lane { 2562306a36Sopenharmony_ci u8 pos; 2662306a36Sopenharmony_ci u8 pol; 2762306a36Sopenharmony_ci}; 2862306a36Sopenharmony_ci 2962306a36Sopenharmony_cistruct csiphy_lanes_cfg { 3062306a36Sopenharmony_ci int num_data; 3162306a36Sopenharmony_ci struct csiphy_lane *data; 3262306a36Sopenharmony_ci struct csiphy_lane clk; 3362306a36Sopenharmony_ci}; 3462306a36Sopenharmony_ci 3562306a36Sopenharmony_cistruct csiphy_csi2_cfg { 3662306a36Sopenharmony_ci struct csiphy_lanes_cfg lane_cfg; 3762306a36Sopenharmony_ci}; 3862306a36Sopenharmony_ci 3962306a36Sopenharmony_cistruct csiphy_config { 4062306a36Sopenharmony_ci u8 combo_mode; 4162306a36Sopenharmony_ci u8 csid_id; 4262306a36Sopenharmony_ci struct csiphy_csi2_cfg *csi2; 4362306a36Sopenharmony_ci}; 4462306a36Sopenharmony_ci 4562306a36Sopenharmony_cistruct csiphy_device; 4662306a36Sopenharmony_ci 4762306a36Sopenharmony_cistruct csiphy_hw_ops { 4862306a36Sopenharmony_ci /* 4962306a36Sopenharmony_ci * csiphy_get_lane_mask - Calculate CSI2 lane mask configuration parameter 5062306a36Sopenharmony_ci * @lane_cfg - CSI2 lane configuration 5162306a36Sopenharmony_ci * 5262306a36Sopenharmony_ci * Return lane mask 5362306a36Sopenharmony_ci */ 5462306a36Sopenharmony_ci u8 (*get_lane_mask)(struct csiphy_lanes_cfg *lane_cfg); 5562306a36Sopenharmony_ci void (*hw_version_read)(struct csiphy_device *csiphy, 5662306a36Sopenharmony_ci struct device *dev); 5762306a36Sopenharmony_ci void (*reset)(struct csiphy_device *csiphy); 5862306a36Sopenharmony_ci void (*lanes_enable)(struct csiphy_device *csiphy, 5962306a36Sopenharmony_ci struct csiphy_config *cfg, 6062306a36Sopenharmony_ci s64 link_freq, u8 lane_mask); 6162306a36Sopenharmony_ci void (*lanes_disable)(struct csiphy_device *csiphy, 6262306a36Sopenharmony_ci struct csiphy_config *cfg); 6362306a36Sopenharmony_ci irqreturn_t (*isr)(int irq, void *dev); 6462306a36Sopenharmony_ci}; 6562306a36Sopenharmony_ci 6662306a36Sopenharmony_cistruct csiphy_device { 6762306a36Sopenharmony_ci struct camss *camss; 6862306a36Sopenharmony_ci u8 id; 6962306a36Sopenharmony_ci struct v4l2_subdev subdev; 7062306a36Sopenharmony_ci struct media_pad pads[MSM_CSIPHY_PADS_NUM]; 7162306a36Sopenharmony_ci void __iomem *base; 7262306a36Sopenharmony_ci void __iomem *base_clk_mux; 7362306a36Sopenharmony_ci u32 irq; 7462306a36Sopenharmony_ci char irq_name[30]; 7562306a36Sopenharmony_ci struct camss_clock *clock; 7662306a36Sopenharmony_ci bool *rate_set; 7762306a36Sopenharmony_ci int nclocks; 7862306a36Sopenharmony_ci u32 timer_clk_rate; 7962306a36Sopenharmony_ci struct csiphy_config cfg; 8062306a36Sopenharmony_ci struct v4l2_mbus_framefmt fmt[MSM_CSIPHY_PADS_NUM]; 8162306a36Sopenharmony_ci const struct csiphy_hw_ops *ops; 8262306a36Sopenharmony_ci const struct csiphy_format *formats; 8362306a36Sopenharmony_ci unsigned int nformats; 8462306a36Sopenharmony_ci}; 8562306a36Sopenharmony_ci 8662306a36Sopenharmony_cistruct resources; 8762306a36Sopenharmony_ci 8862306a36Sopenharmony_ciint msm_csiphy_subdev_init(struct camss *camss, 8962306a36Sopenharmony_ci struct csiphy_device *csiphy, 9062306a36Sopenharmony_ci const struct resources *res, u8 id); 9162306a36Sopenharmony_ci 9262306a36Sopenharmony_ciint msm_csiphy_register_entity(struct csiphy_device *csiphy, 9362306a36Sopenharmony_ci struct v4l2_device *v4l2_dev); 9462306a36Sopenharmony_ci 9562306a36Sopenharmony_civoid msm_csiphy_unregister_entity(struct csiphy_device *csiphy); 9662306a36Sopenharmony_ci 9762306a36Sopenharmony_ciextern const struct csiphy_hw_ops csiphy_ops_2ph_1_0; 9862306a36Sopenharmony_ciextern const struct csiphy_hw_ops csiphy_ops_3ph_1_0; 9962306a36Sopenharmony_ci 10062306a36Sopenharmony_ci#endif /* QC_MSM_CAMSS_CSIPHY_H */ 101