Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp3001453yba; Tue, 16 Apr 2019 02:30:51 -0700 (PDT) X-Google-Smtp-Source: APXvYqzfZi2B4Ui/kjrxWsDa0wZ3tGKtRBYmlBzYc10H/TmBR30oM2Hb5nsGMJjio/8PyK90arcU X-Received: by 2002:a62:1d0d:: with SMTP id d13mr81781106pfd.96.1555407051364; Tue, 16 Apr 2019 02:30:51 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1555407051; cv=none; d=google.com; s=arc-20160816; b=IVPPti98RBq2OQL4HNlB8SlrAq7DpUOqpXAE/XAkcoiqcoszhEEqFDeR3FcJVKESkq AX021pwFMpRPLyUkW+OkedX4HbKDlU3kI/07oTy2xxXvlQhriDouPfp2XwplQSn20xWL 8RCu0NhhJhbQLdv2lTJ8YQkZUWD+RVU//qdKd77DrPUwv597C/Z028MSlPcwYLxJhCQm pMbzFfK7quSrAvigy7NeKN/GaCqtZUvmKgjRZ3VniVkH1y5LjQqc4YW3HQSAsy2FI1EO pa1p+YBdMXLqSiRIR4TpYr3IdKfz2iHTIukEDfUX1ukd1kATi0/ltoD6gy26Zz+xhwGZ wWWg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from; bh=mIA2Mee8CvyIFy7dfhoi/3IL2zR9fvjco46MxD1cORo=; b=avLlTRCMoXFjgJdeqT+kpVg+czwNX1pCs+dQqUoe7Bdq+8ZJ07UM3zThCa1c/GVnD9 fJqFZqDXb2qxsuf2jbFt99+wSzDNbFBbcvJP5z+FpS5zU3yt8iU13KQ45hnvKC8lw1M3 qJTOxFFKHQpiWpvruSYUkDAyanVI0njkYGYPP51mWjEr9wRPodf5xKuzdmB9ttYG/don hYXYCzcl/wXoegNmtQ/t/xq7745pd+J2bsINTneD+RcT/BFIhHeKqoYSEYyKKFrQzCtm D/+YurzWGuAEnkx1aGtnp4ypDM4AeAwe+D4buAfOHraRSfqYPKcCcLsMTgKimqi3bbUu CWeA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id i9si36997397pgk.207.2019.04.16.02.30.35; Tue, 16 Apr 2019 02:30:51 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726739AbfDPJ2b (ORCPT + 99 others); Tue, 16 Apr 2019 05:28:31 -0400 Received: from mailgw02.mediatek.com ([210.61.82.184]:25215 "EHLO mailgw02.mediatek.com" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1728980AbfDPJ2F (ORCPT ); Tue, 16 Apr 2019 05:28:05 -0400 X-UUID: 782da1d7348f4c4a93dddd42978a3249-20190416 X-UUID: 782da1d7348f4c4a93dddd42978a3249-20190416 Received: from mtkexhb01.mediatek.inc [(172.21.101.102)] by mailgw02.mediatek.com (envelope-from ) (mhqrelay.mediatek.com ESMTP with TLS) with ESMTP id 1272196769; Tue, 16 Apr 2019 17:27:54 +0800 Received: from MTKCAS06.mediatek.inc (172.21.101.30) by mtkmbs01n2.mediatek.inc (172.21.101.79) with Microsoft SMTP Server (TLS) id 15.0.1395.4; Tue, 16 Apr 2019 17:27:47 +0800 Received: from mtksdccf07.mediatek.inc (172.21.84.99) by MTKCAS06.mediatek.inc (172.21.101.73) with Microsoft SMTP Server id 15.0.1395.4 via Frontend Transport; Tue, 16 Apr 2019 17:27:47 +0800 From: Stu Hsieh To: Mauro Carvalho Chehab , Rob Herring , CK Hu CC: Mark Rutland , Matthias Brugger , Stu Hsieh , , , , , , Subject: [PATCH v2 06/15] [media] mtk-mipicsi: add function to support SerDes for link number Date: Tue, 16 Apr 2019 17:27:34 +0800 Message-ID: <1555406863-18069-7-git-send-email-stu.hsieh@mediatek.com> X-Mailer: git-send-email 1.9.1 In-Reply-To: <1555406863-18069-1-git-send-email-stu.hsieh@mediatek.com> References: <1555406863-18069-1-git-send-email-stu.hsieh@mediatek.com> MIME-Version: 1.0 Content-Type: text/plain X-TM-SNTS-SMTP: 30009AA0D98A828B24D83753B640F6CBFD3112A4F8698811C6D2BDE8875B76262000:8 X-MTK: N Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This patch add function to support SerDes for link number. Mt2712 can server at most four camera link for each mipicsi port. Therefore, driver need to know how many camera link in SerDes and set the mipicsi HW to serve. Signed-off-by: Stu Hsieh --- .../media/platform/mtk-mipicsi/mtk_mipicsi.c | 64 +++++++++++++++++++ 1 file changed, 64 insertions(+) diff --git a/drivers/media/platform/mtk-mipicsi/mtk_mipicsi.c b/drivers/media/platform/mtk-mipicsi/mtk_mipicsi.c index 10782fccca79..ec05f3b38cc9 100644 --- a/drivers/media/platform/mtk-mipicsi/mtk_mipicsi.c +++ b/drivers/media/platform/mtk-mipicsi/mtk_mipicsi.c @@ -56,12 +56,16 @@ #define MIPICSI_COMMON_CLK 2 #define MTK_CAMDMA_MAX_NUM 4U #define MIPICSI_CLK (MIPICSI_COMMON_CLK + MTK_CAMDMA_MAX_NUM) +#define MAX_DES_LINK 4U +#define SUBDEV_LINK_REG 0x49 #define MTK_DATAWIDTH_8 (0x01U << 7U) #define MAX_SUPPORT_WIDTH 4096U #define MAX_SUPPORT_HEIGHT 4096U #define MAX_BUFFER_NUM 32U #define VID_LIMIT_BYTES (100U * 1024U * 1024U) +#define SerDes_support 1 + /* buffer for one video frame */ struct mtk_mipicsi_buf { struct list_head queue; @@ -92,6 +96,7 @@ struct mtk_mipicsi_dev { bool streamon; unsigned long frame_cnt[MTK_CAMDMA_MAX_NUM]; unsigned int link; + u8 link_reg_val; unsigned long enqueue_cnt; unsigned long dequeue_cnt; struct v4l2_ctrl_handler ctrl_hdl; @@ -113,6 +118,64 @@ struct mtk_mipicsi_dev { V4L2_MBUS_PCLK_SAMPLE_FALLING | \ V4L2_MBUS_DATA_ACTIVE_HIGH) +static int get_subdev_register(const struct soc_camera_device *icd, + struct v4l2_dbg_register *reg) +{ + struct v4l2_subdev *sd = soc_camera_to_subdev(icd); + int ret = 0; + + reg->match.type = V4L2_CHIP_MATCH_SUBDEV; + reg->match.addr = 0; + ret = v4l2_subdev_call(sd, core, g_register, reg); + if (ret != 2) { + dev_err(icd->parent, "mipicsi get des register 0x%llx fail, ret=%d\n", + reg->reg, ret); + return -EIO; + } + + dev_info(icd->parent, "read DES [reg/val/ret] is [0x%llx/0x%llx/%d]\n", + reg->reg, reg->val, ret); + return ret; +} + +static int get_subdev_link(const struct soc_camera_device *icd, + unsigned int *link, u8 *link_reg_val) +{ + struct v4l2_dbg_register reg; + int ret = 0; + unsigned int index = 0U; + *link_reg_val = 0x0U; + + if (SerDes_support == 0) { + *link = 1; + *link_reg_val = 0x1; + dev_info(icd->parent, "subdev not support SerDes\n"); + return 0; + } + + if (link == NULL) + return -EINVAL; + + memset(®, 0, sizeof(reg)); + /*get camera link number*/ + reg.reg = SUBDEV_LINK_REG; + ret = get_subdev_register(icd, ®); + if (ret < 0) + return ret; + + *link = 0U; + for (index = 0U; index < MAX_DES_LINK; ++index) { + if ((reg.val & 0x01U) == 0x01U) { + *link += 1U; + *link_reg_val |= (0x01U << index); + } + reg.val >>= 1U; + } + + dev_info(icd->parent, "%u camera linked to sub device\n", *link); + return 0; +} + static u32 get_bytesperline(const u32 fmt, const u32 width) { u32 bytesperline = 0; @@ -144,6 +207,7 @@ static int mtk_mipicsi_add_device(struct soc_camera_device *icd) u32 height; u32 fmt; + (void)get_subdev_link(icd, &mipicsi->link, &mipicsi->link_reg_val); /* Get width/height info from subdev. Then use them to set register */ ret = v4l2_subdev_call(sd, pad, get_fmt, NULL, &format); if (ret < 0) { -- 2.18.0