162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Copyright 2019-2023 NXP 462306a36Sopenharmony_ci */ 562306a36Sopenharmony_ci 662306a36Sopenharmony_ci#include <linux/regmap.h> 762306a36Sopenharmony_ci 862306a36Sopenharmony_ci#include <media/mipi-csi2.h> 962306a36Sopenharmony_ci 1062306a36Sopenharmony_ci#include "imx8-isi-core.h" 1162306a36Sopenharmony_ci 1262306a36Sopenharmony_ci/* ----------------------------------------------------------------------------- 1362306a36Sopenharmony_ci * i.MX8MN and i.MX8MP gasket 1462306a36Sopenharmony_ci */ 1562306a36Sopenharmony_ci 1662306a36Sopenharmony_ci#define GASKET_BASE(n) (0x0060 + (n) * 0x30) 1762306a36Sopenharmony_ci 1862306a36Sopenharmony_ci#define GASKET_CTRL 0x0000 1962306a36Sopenharmony_ci#define GASKET_CTRL_DATA_TYPE(dt) ((dt) << 8) 2062306a36Sopenharmony_ci#define GASKET_CTRL_DATA_TYPE_MASK (0x3f << 8) 2162306a36Sopenharmony_ci#define GASKET_CTRL_DUAL_COMP_ENABLE BIT(1) 2262306a36Sopenharmony_ci#define GASKET_CTRL_ENABLE BIT(0) 2362306a36Sopenharmony_ci 2462306a36Sopenharmony_ci#define GASKET_HSIZE 0x0004 2562306a36Sopenharmony_ci#define GASKET_VSIZE 0x0008 2662306a36Sopenharmony_ci 2762306a36Sopenharmony_cistatic void mxc_imx8_gasket_enable(struct mxc_isi_dev *isi, 2862306a36Sopenharmony_ci const struct v4l2_mbus_frame_desc *fd, 2962306a36Sopenharmony_ci const struct v4l2_mbus_framefmt *fmt, 3062306a36Sopenharmony_ci const unsigned int port) 3162306a36Sopenharmony_ci{ 3262306a36Sopenharmony_ci u32 val; 3362306a36Sopenharmony_ci 3462306a36Sopenharmony_ci regmap_write(isi->gasket, GASKET_BASE(port) + GASKET_HSIZE, fmt->width); 3562306a36Sopenharmony_ci regmap_write(isi->gasket, GASKET_BASE(port) + GASKET_VSIZE, fmt->height); 3662306a36Sopenharmony_ci 3762306a36Sopenharmony_ci val = GASKET_CTRL_DATA_TYPE(fd->entry[0].bus.csi2.dt); 3862306a36Sopenharmony_ci if (fd->entry[0].bus.csi2.dt == MIPI_CSI2_DT_YUV422_8B) 3962306a36Sopenharmony_ci val |= GASKET_CTRL_DUAL_COMP_ENABLE; 4062306a36Sopenharmony_ci 4162306a36Sopenharmony_ci val |= GASKET_CTRL_ENABLE; 4262306a36Sopenharmony_ci regmap_write(isi->gasket, GASKET_BASE(port) + GASKET_CTRL, val); 4362306a36Sopenharmony_ci} 4462306a36Sopenharmony_ci 4562306a36Sopenharmony_cistatic void mxc_imx8_gasket_disable(struct mxc_isi_dev *isi, 4662306a36Sopenharmony_ci const unsigned int port) 4762306a36Sopenharmony_ci{ 4862306a36Sopenharmony_ci regmap_write(isi->gasket, GASKET_BASE(port) + GASKET_CTRL, 0); 4962306a36Sopenharmony_ci} 5062306a36Sopenharmony_ci 5162306a36Sopenharmony_ciconst struct mxc_gasket_ops mxc_imx8_gasket_ops = { 5262306a36Sopenharmony_ci .enable = mxc_imx8_gasket_enable, 5362306a36Sopenharmony_ci .disable = mxc_imx8_gasket_disable, 5462306a36Sopenharmony_ci}; 5562306a36Sopenharmony_ci 5662306a36Sopenharmony_ci/* ----------------------------------------------------------------------------- 5762306a36Sopenharmony_ci * i.MX93 gasket 5862306a36Sopenharmony_ci */ 5962306a36Sopenharmony_ci 6062306a36Sopenharmony_ci#define DISP_MIX_CAMERA_MUX 0x30 6162306a36Sopenharmony_ci#define DISP_MIX_CAMERA_MUX_DATA_TYPE(x) (((x) & 0x3f) << 3) 6262306a36Sopenharmony_ci#define DISP_MIX_CAMERA_MUX_GASKET_ENABLE BIT(16) 6362306a36Sopenharmony_ci 6462306a36Sopenharmony_cistatic void mxc_imx93_gasket_enable(struct mxc_isi_dev *isi, 6562306a36Sopenharmony_ci const struct v4l2_mbus_frame_desc *fd, 6662306a36Sopenharmony_ci const struct v4l2_mbus_framefmt *fmt, 6762306a36Sopenharmony_ci const unsigned int port) 6862306a36Sopenharmony_ci{ 6962306a36Sopenharmony_ci u32 val; 7062306a36Sopenharmony_ci 7162306a36Sopenharmony_ci val = DISP_MIX_CAMERA_MUX_DATA_TYPE(fd->entry[0].bus.csi2.dt); 7262306a36Sopenharmony_ci val |= DISP_MIX_CAMERA_MUX_GASKET_ENABLE; 7362306a36Sopenharmony_ci regmap_write(isi->gasket, DISP_MIX_CAMERA_MUX, val); 7462306a36Sopenharmony_ci} 7562306a36Sopenharmony_ci 7662306a36Sopenharmony_cistatic void mxc_imx93_gasket_disable(struct mxc_isi_dev *isi, 7762306a36Sopenharmony_ci unsigned int port) 7862306a36Sopenharmony_ci{ 7962306a36Sopenharmony_ci regmap_write(isi->gasket, DISP_MIX_CAMERA_MUX, 0); 8062306a36Sopenharmony_ci} 8162306a36Sopenharmony_ci 8262306a36Sopenharmony_ciconst struct mxc_gasket_ops mxc_imx93_gasket_ops = { 8362306a36Sopenharmony_ci .enable = mxc_imx93_gasket_enable, 8462306a36Sopenharmony_ci .disable = mxc_imx93_gasket_disable, 8562306a36Sopenharmony_ci}; 86