On Fri, Jun 05, 2026 at 03:14:41PM +0200, David Heidelberg wrote:
> Inherit C-PHY information from CSIPHY, so we can configure CSID
> properly.
>
> CSI2_RX_CFG0_PHY_TYPE_SEL must be set to 1, when C-PHY mode is used.
>
> Reviewed-by: Bryan O'Donoghue <[email protected]>
> Acked-by: Cory Keitz <[email protected]>
> Signed-off-by: David Heidelberg <[email protected]>
> ---
>  drivers/media/platform/qcom/camss/camss-csid-gen2.c | 1 +
>  drivers/media/platform/qcom/camss/camss-csid.c      | 5 +++++
>  drivers/media/platform/qcom/camss/camss-csid.h      | 6 ++++++
>  3 files changed, 12 insertions(+)
>
> diff --git a/drivers/media/platform/qcom/camss/camss-csid-gen2.c 
> b/drivers/media/platform/qcom/camss/camss-csid-gen2.c
> index eadcb2f7e3aaa..a5b406cc8ead3 100644
> --- a/drivers/media/platform/qcom/camss/camss-csid-gen2.c
> +++ b/drivers/media/platform/qcom/camss/camss-csid-gen2.c
> @@ -178,16 +178,17 @@ static void __csid_configure_rx(struct csid_device 
> *csid,
>       int val;
>
>       if (!lane_cnt)
>               lane_cnt = 4;
>
>       val = (lane_cnt - 1) << CSI2_RX_CFG0_NUM_ACTIVE_LANES;
>       val |= phy->lane_assign << CSI2_RX_CFG0_DL0_INPUT_SEL;
>       val |= phy->csiphy_id << CSI2_RX_CFG0_PHY_NUM_SEL;
> +     val |= csid->phy.phy_sel << CSI2_RX_CFG0_PHY_TYPE_SEL;


It is fine for now. Suggest change to FIELD_PREP() in future.

Reviewed-by: Frank Li <[email protected]>

>       writel_relaxed(val, csid->base + CSID_CSI2_RX_CFG0);
>
>       val = 1 << CSI2_RX_CFG1_PACKET_ECC_CORRECTION_EN;
>       if (vc > 3)
>               val |= 1 << CSI2_RX_CFG1_VC_MODE;
>       val |= 1 << CSI2_RX_CFG1_MISR_EN;
>       writel_relaxed(val, csid->base + CSID_CSI2_RX_CFG1);
>  }
> diff --git a/drivers/media/platform/qcom/camss/camss-csid.c 
> b/drivers/media/platform/qcom/camss/camss-csid.c
> index 48459b46a981b..bcc34ac9dd212 100644
> --- a/drivers/media/platform/qcom/camss/camss-csid.c
> +++ b/drivers/media/platform/qcom/camss/camss-csid.c
> @@ -1286,16 +1286,21 @@ static int csid_link_setup(struct media_entity 
> *entity,
>                       /* do no allow a link from CSIPHY to CSID */
>                       if (!csiphy->cfg.csi2)
>                               return -EPERM;
>
>                       csid->phy.csiphy_id = csiphy->id;
>
>                       lane_cfg = &csiphy->cfg.csi2->lane_cfg;
>                       csid->phy.lane_cnt = lane_cfg->num_data;
> +                     if (lane_cfg->phy_cfg == V4L2_MBUS_CSI2_CPHY)
> +                             csid->phy.phy_sel = CSID_PHY_SEL_CPHY;
> +                     else
> +                             csid->phy.phy_sel = CSID_PHY_SEL_DPHY;
> +
>                       csid->phy.lane_assign = csid_get_lane_assign(lane_cfg, 
> lane_cfg->num_data);
>                       csid->tpg_linked = false;
>               }
>       }
>       /* Decide which virtual channels to enable based on which source pads 
> are enabled */
>       if (local->flags & MEDIA_PAD_FL_SOURCE) {
>               struct v4l2_subdev *sd = media_entity_to_v4l2_subdev(entity);
>               struct csid_device *csid = v4l2_get_subdevdata(sd);
> diff --git a/drivers/media/platform/qcom/camss/camss-csid.h 
> b/drivers/media/platform/qcom/camss/camss-csid.h
> index 5296b10f6bac8..e65590b0df69f 100644
> --- a/drivers/media/platform/qcom/camss/camss-csid.h
> +++ b/drivers/media/platform/qcom/camss/camss-csid.h
> @@ -39,16 +39,21 @@ enum csid_testgen_mode {
>       CSID_PAYLOAD_MODE_USER_SPECIFIED = 6,
>       CSID_PAYLOAD_MODE_NUM_SUPPORTED_GEN1 = 6, /* excluding disabled */
>       CSID_PAYLOAD_MODE_COMPLEX_PATTERN = 7,
>       CSID_PAYLOAD_MODE_COLOR_BOX = 8,
>       CSID_PAYLOAD_MODE_COLOR_BARS = 9,
>       CSID_PAYLOAD_MODE_NUM_SUPPORTED_GEN2 = 9, /* excluding disabled */
>  };
>
> +enum csid_phy_sel {
> +     CSID_PHY_SEL_DPHY = 0,
> +     CSID_PHY_SEL_CPHY = 1
> +};
> +
>  struct csid_format_info {
>       u32 code;
>       u8 data_type;
>       u8 decode_format;
>       u8 bpp;
>       u8 spp; /* bus samples per pixel */
>  };
>
> @@ -65,16 +70,17 @@ struct csid_testgen_config {
>  };
>
>  struct csid_phy_config {
>       u8 csiphy_id;
>       u8 lane_cnt;
>       u32 lane_assign;
>       u32 en_vc;
>       u8 need_vc_update;
> +     enum csid_phy_sel phy_sel;
>  };
>
>  struct csid_device;
>
>  struct csid_hw_ops {
>       /*
>        * configure_stream - Configures and starts CSID input stream
>        * @csid: CSID device
>
> --
> 2.53.0
>

Reply via email to