2018-07-25 12:38:14 -04:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0 */
|
2017-08-08 09:30:07 -04:00
|
|
|
/*
|
|
|
|
* camss.h
|
|
|
|
*
|
|
|
|
* Qualcomm MSM Camera Subsystem - Core
|
|
|
|
*
|
|
|
|
* Copyright (c) 2015, The Linux Foundation. All rights reserved.
|
2018-07-25 12:38:13 -04:00
|
|
|
* Copyright (C) 2015-2018 Linaro Ltd.
|
2017-08-08 09:30:07 -04:00
|
|
|
*/
|
|
|
|
#ifndef QC_MSM_CAMSS_H
|
|
|
|
#define QC_MSM_CAMSS_H
|
|
|
|
|
2018-07-25 12:38:27 -04:00
|
|
|
#include <linux/device.h>
|
2017-08-08 09:30:07 -04:00
|
|
|
#include <linux/types.h>
|
|
|
|
#include <media/v4l2-async.h>
|
|
|
|
#include <media/v4l2-device.h>
|
|
|
|
#include <media/v4l2-subdev.h>
|
|
|
|
#include <media/media-device.h>
|
|
|
|
#include <media/media-entity.h>
|
|
|
|
|
|
|
|
#include "camss-csid.h"
|
|
|
|
#include "camss-csiphy.h"
|
|
|
|
#include "camss-ispif.h"
|
|
|
|
#include "camss-vfe.h"
|
2024-05-22 18:46:53 +03:00
|
|
|
#include "camss-format.h"
|
2017-08-08 09:30:07 -04:00
|
|
|
|
|
|
|
#define to_camss(ptr_module) \
|
|
|
|
container_of(ptr_module, struct camss, ptr_module)
|
|
|
|
|
|
|
|
#define to_device(ptr_module) \
|
|
|
|
(to_camss(ptr_module)->dev)
|
|
|
|
|
|
|
|
#define module_pointer(ptr_module, index) \
|
|
|
|
((const struct ptr_module##_device (*)[]) &(ptr_module[-(index)]))
|
|
|
|
|
|
|
|
#define to_camss_index(ptr_module, index) \
|
|
|
|
container_of(module_pointer(ptr_module, index), \
|
|
|
|
struct camss, ptr_module)
|
|
|
|
|
|
|
|
#define to_device_index(ptr_module, index) \
|
|
|
|
(to_camss_index(ptr_module, index)->dev)
|
|
|
|
|
2018-07-25 12:38:26 -04:00
|
|
|
#define CAMSS_RES_MAX 17
|
2017-08-08 09:30:07 -04:00
|
|
|
|
2023-09-25 16:46:52 +01:00
|
|
|
struct camss_subdev_resources {
|
2022-01-11 13:52:09 +01:00
|
|
|
char *regulators[CAMSS_RES_MAX];
|
2017-08-08 09:30:07 -04:00
|
|
|
char *clock[CAMSS_RES_MAX];
|
2023-09-25 16:46:51 +01:00
|
|
|
char *clock_for_reset[CAMSS_RES_MAX];
|
2017-08-08 09:30:17 -04:00
|
|
|
u32 clock_rate[CAMSS_RES_MAX][CAMSS_RES_MAX];
|
2017-08-08 09:30:07 -04:00
|
|
|
char *reg[CAMSS_RES_MAX];
|
|
|
|
char *interrupt[CAMSS_RES_MAX];
|
2024-05-22 18:46:52 +03:00
|
|
|
union {
|
|
|
|
struct csiphy_subdev_resources csiphy;
|
|
|
|
struct csid_subdev_resources csid;
|
|
|
|
struct vfe_subdev_resources vfe;
|
|
|
|
};
|
2017-08-08 09:30:07 -04:00
|
|
|
};
|
|
|
|
|
2021-12-22 01:37:49 +01:00
|
|
|
struct icc_bw_tbl {
|
|
|
|
u32 avg;
|
|
|
|
u32 peak;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct resources_icc {
|
|
|
|
char *name;
|
|
|
|
struct icc_bw_tbl icc_bw_tbl;
|
|
|
|
};
|
|
|
|
|
2024-08-14 17:14:34 +01:00
|
|
|
struct resources_wrapper {
|
|
|
|
char *reg;
|
|
|
|
};
|
|
|
|
|
2018-07-25 12:38:27 -04:00
|
|
|
enum pm_domain {
|
2021-03-16 18:19:21 +01:00
|
|
|
PM_DOMAIN_VFE0 = 0,
|
|
|
|
PM_DOMAIN_VFE1 = 1,
|
2021-03-16 18:19:22 +01:00
|
|
|
PM_DOMAIN_VFELITE = 2, /* VFELITE / TOP GDSC */
|
2018-07-25 12:38:27 -04:00
|
|
|
};
|
|
|
|
|
2018-07-25 12:38:26 -04:00
|
|
|
enum camss_version {
|
2024-12-07 00:48:57 +05:30
|
|
|
CAMSS_660,
|
2024-12-07 00:48:58 +05:30
|
|
|
CAMSS_7280,
|
2018-07-25 12:38:26 -04:00
|
|
|
CAMSS_8x16,
|
2024-11-03 10:45:36 +01:00
|
|
|
CAMSS_8x53,
|
2018-07-25 12:38:26 -04:00
|
|
|
CAMSS_8x96,
|
2021-12-22 01:37:36 +01:00
|
|
|
CAMSS_8250,
|
2024-02-22 17:17:01 +00:00
|
|
|
CAMSS_8280XP,
|
2024-12-07 00:48:57 +05:30
|
|
|
CAMSS_845,
|
2025-01-13 10:01:30 +05:30
|
|
|
CAMSS_8550,
|
2025-03-14 23:36:00 +00:00
|
|
|
CAMSS_X1E80100,
|
2018-07-25 12:38:26 -04:00
|
|
|
};
|
|
|
|
|
2021-12-22 01:37:49 +01:00
|
|
|
enum icc_count {
|
|
|
|
ICC_DEFAULT_COUNT = 0,
|
|
|
|
ICC_SM8250_COUNT = 4,
|
|
|
|
};
|
|
|
|
|
2023-09-25 16:46:53 +01:00
|
|
|
struct camss_resources {
|
2023-09-25 16:46:55 +01:00
|
|
|
enum camss_version version;
|
2023-12-06 13:25:00 +01:00
|
|
|
const char *pd_name;
|
2023-09-25 16:46:53 +01:00
|
|
|
const struct camss_subdev_resources *csiphy_res;
|
|
|
|
const struct camss_subdev_resources *csid_res;
|
|
|
|
const struct camss_subdev_resources *ispif_res;
|
|
|
|
const struct camss_subdev_resources *vfe_res;
|
2024-08-14 17:14:34 +01:00
|
|
|
const struct resources_wrapper *csid_wrapper_res;
|
2023-09-25 16:46:54 +01:00
|
|
|
const struct resources_icc *icc_res;
|
|
|
|
const unsigned int icc_path_num;
|
2023-09-25 16:46:55 +01:00
|
|
|
const unsigned int csiphy_num;
|
|
|
|
const unsigned int csid_num;
|
|
|
|
const unsigned int vfe_num;
|
2024-05-22 18:46:58 +03:00
|
|
|
int (*link_entities)(struct camss *camss);
|
2023-09-25 16:46:53 +01:00
|
|
|
};
|
|
|
|
|
2017-08-08 09:30:07 -04:00
|
|
|
struct camss {
|
|
|
|
struct v4l2_device v4l2_dev;
|
|
|
|
struct v4l2_async_notifier notifier;
|
|
|
|
struct media_device media_dev;
|
|
|
|
struct device *dev;
|
2018-07-25 12:38:26 -04:00
|
|
|
struct csiphy_device *csiphy;
|
|
|
|
struct csid_device *csid;
|
2021-03-16 18:19:14 +01:00
|
|
|
struct ispif_device *ispif;
|
2018-07-25 12:38:26 -04:00
|
|
|
struct vfe_device *vfe;
|
2024-08-14 17:14:34 +01:00
|
|
|
void __iomem *csid_wrapper_base;
|
2017-08-08 09:30:07 -04:00
|
|
|
atomic_t ref_count;
|
2022-05-12 09:23:18 +01:00
|
|
|
int genpd_num;
|
2023-11-23 17:03:03 +00:00
|
|
|
struct device *genpd;
|
|
|
|
struct device_link *genpd_link;
|
2021-12-22 01:37:49 +01:00
|
|
|
struct icc_path *icc_path[ICC_SM8250_COUNT];
|
2023-09-25 16:46:53 +01:00
|
|
|
const struct camss_resources *res;
|
2017-08-08 09:30:07 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
struct camss_camera_interface {
|
|
|
|
u8 csiphy_id;
|
|
|
|
struct csiphy_csi2_cfg csi2;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct camss_async_subdev {
|
2023-02-16 14:54:53 +01:00
|
|
|
struct v4l2_async_connection asd; /* must be first */
|
2017-08-08 09:30:07 -04:00
|
|
|
struct camss_camera_interface interface;
|
|
|
|
};
|
|
|
|
|
2017-08-08 09:30:17 -04:00
|
|
|
struct camss_clock {
|
|
|
|
struct clk *clk;
|
|
|
|
const char *name;
|
|
|
|
u32 *freq;
|
|
|
|
u32 nfreqs;
|
|
|
|
};
|
|
|
|
|
2024-05-22 18:46:59 +03:00
|
|
|
struct parent_dev_ops {
|
|
|
|
int (*get)(struct camss *camss, int id);
|
|
|
|
int (*put)(struct camss *camss, int id);
|
|
|
|
void __iomem *(*get_base_address)(struct camss *camss, int id);
|
|
|
|
};
|
|
|
|
|
2017-08-08 09:30:17 -04:00
|
|
|
void camss_add_clock_margin(u64 *rate);
|
|
|
|
int camss_enable_clocks(int nclocks, struct camss_clock *clock,
|
|
|
|
struct device *dev);
|
|
|
|
void camss_disable_clocks(int nclocks, struct camss_clock *clock);
|
2024-12-16 11:25:31 +02:00
|
|
|
struct media_pad *camss_find_sensor_pad(struct media_entity *entity);
|
2021-02-17 23:11:33 +01:00
|
|
|
s64 camss_get_link_freq(struct media_entity *entity, unsigned int bpp,
|
|
|
|
unsigned int lanes);
|
2021-02-17 23:11:34 +01:00
|
|
|
int camss_get_pixel_clock(struct media_entity *entity, u64 *pixel_clock);
|
2018-07-25 12:38:27 -04:00
|
|
|
int camss_pm_domain_on(struct camss *camss, int id);
|
|
|
|
void camss_pm_domain_off(struct camss *camss, int id);
|
2024-05-22 18:46:59 +03:00
|
|
|
int camss_vfe_get(struct camss *camss, int id);
|
|
|
|
void camss_vfe_put(struct camss *camss, int id);
|
2017-08-08 09:30:07 -04:00
|
|
|
void camss_delete(struct camss *camss);
|
2025-01-13 10:01:26 +05:30
|
|
|
void camss_buf_done(struct camss *camss, int hw_id, int port_id);
|
|
|
|
void camss_reg_update(struct camss *camss, int hw_id,
|
|
|
|
int port_id, bool is_clear);
|
2017-08-08 09:30:07 -04:00
|
|
|
|
|
|
|
#endif /* QC_MSM_CAMSS_H */
|