Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp5215335ybi; Tue, 4 Jun 2019 03:13:52 -0700 (PDT) X-Google-Smtp-Source: APXvYqwoWaqsyNZf8rh+ESF7rdFPH+dD5pot+ip/m5hWKn95s5yhx5xiA2z7YQ9vUStGg0qLRVQP X-Received: by 2002:a17:902:d916:: with SMTP id c22mr10008553plz.195.1559643232630; Tue, 04 Jun 2019 03:13:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1559643232; cv=none; d=google.com; s=arc-20160816; b=R4wrMrM4oeSW6hoOFJz8aMQuiE8iZ8ehb/eaHs3o5mMmROu4btyGmNnT8ASanVQLf5 OvKiTvRKB7faH4fX+qgzl9ahLbS0DEAt+0+HIBKR//zVGOWsl7eyRyitE25QxIVP0p6Z LK5wgkPMp6lriWbmdhl9Bu173iBlnkKMM3TE7Ha+jduT7DzV+e+8LOrWmEGoOXzXbAVL ekDtdWoPosW5yI3Cc3q/s+Kecz98i/mKTJKrEohlGn6kr+2W7ir1OsNcmfpqUhjhDaTA xTQP1wAOo4WMVXzgmscL4zoXiqvGhRmHiArKTWy8KnDCZAUHuci+xVFdG8WiylrjwVP1 Ifow== 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=pHacoeGxEE3e/zRqhtm7tQq3Q78Ibcrjfd881dUqFCw=; b=mAPpZdH7WNmse5ABC/COMshitU4sBNby7WiI6OXvxowhIkY3HD0q0x2jmKoXAfDFqb /GVzMP+XdcN0jrW5Zt6A9AdaLGUjH+FsddygVWNveki53Q+KQg1RnUx2hMoiVYlkzKEa Qeeca8XtrKOqOI58LydWflULSzOR4dGCvwTd4vpkyXLtOWWy2N49XPwnY4XOnzBWONnB ny0deP7KiZS8SRRZ5A0B7lx/lBHcq0kTZk9ezjQBLUZcPDPkrQMA4iUQtAxoH31E1TQg nRZKus0xOqEWmsixxWeZHvPBLYXZyW//sEGLELi5EEAv/7P+jSSJCYGNMJqNGtjxiheX FpmA== 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 az12si7950042plb.165.2019.06.04.03.13.35; Tue, 04 Jun 2019 03:13:52 -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 S1727318AbfFDKMO (ORCPT + 99 others); Tue, 4 Jun 2019 06:12:14 -0400 Received: from mailgw01.mediatek.com ([210.61.82.183]:16528 "EHLO mailgw01.mediatek.com" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1727110AbfFDKMI (ORCPT ); Tue, 4 Jun 2019 06:12:08 -0400 X-UUID: 913cc3a306454d96b3044610a02c493d-20190604 X-UUID: 913cc3a306454d96b3044610a02c493d-20190604 Received: from mtkmrs01.mediatek.inc [(172.21.131.159)] by mailgw01.mediatek.com (envelope-from ) (mhqrelay.mediatek.com ESMTP with TLS) with ESMTP id 1893859149; Tue, 04 Jun 2019 18:12:02 +0800 Received: from mtkcas08.mediatek.inc (172.21.101.126) by mtkmbs01n1.mediatek.inc (172.21.101.68) with Microsoft SMTP Server (TLS) id 15.0.1395.4; Tue, 4 Jun 2019 18:12:01 +0800 Received: from mtksdccf07.mediatek.inc (172.21.84.99) by mtkcas08.mediatek.inc (172.21.101.73) with Microsoft SMTP Server id 15.0.1395.4 via Frontend Transport; Tue, 4 Jun 2019 18:12:01 +0800 From: Stu Hsieh To: Mauro Carvalho Chehab , Rob Herring , CK Hu CC: Mark Rutland , Matthias Brugger , Stu Hsieh , , , , , , Subject: [PATCH v4 10/14] [media] mtk-mipicsi: set the output address in HW reg Date: Tue, 4 Jun 2019 18:11:51 +0800 Message-ID: <1559643115-15124-11-git-send-email-stu.hsieh@mediatek.com> X-Mailer: git-send-email 1.9.1 In-Reply-To: <1559643115-15124-1-git-send-email-stu.hsieh@mediatek.com> References: <1559643115-15124-1-git-send-email-stu.hsieh@mediatek.com> MIME-Version: 1.0 Content-Type: text/plain X-MTK: N Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This patch set the output address in HW reg when buffer queue and ISR. Signed-off-by: Stu Hsieh --- .../media/platform/mtk-mipicsi/mtk_mipicsi.c | 35 +++++++++++++++++++ 1 file changed, 35 insertions(+) diff --git a/drivers/media/platform/mtk-mipicsi/mtk_mipicsi.c b/drivers/media/platform/mtk-mipicsi/mtk_mipicsi.c index dc5c5c888914..9e45786a0282 100644 --- a/drivers/media/platform/mtk-mipicsi/mtk_mipicsi.c +++ b/drivers/media/platform/mtk-mipicsi/mtk_mipicsi.c @@ -100,6 +100,7 @@ #define CAMSV_TG_SEN_GRAB_LIN 0x50C #define CAMSV_TG_PATH_CFG 0x510 +#define IMGO_BASE_ADDR 0x220 #define IMGO_XSIZE 0x230 #define IMGO_YSIZE 0x234 #define IMGO_STRIDE 0x238 @@ -538,6 +539,32 @@ static int mtk_mipicsi_vb2_prepare(struct vb2_buffer *vb) return 0; } +static void mtk_mipicsi_fill_buffer(void __iomem *base, dma_addr_t dma_handle) +{ + writel(dma_handle, base + IMGO_BASE_ADDR); +} + +static void mtk_mipicsi_write_camsv(struct mtk_mipicsi_dev *mipicsi, + unsigned int index, + unsigned int max_camsv_num) +{ + struct mtk_mipicsi_channel *ch = mipicsi->channel; + unsigned int i = 0; + u8 link_index = 0; + u32 bytesperline = mipicsi->fmt.fmt.pix.bytesperline; + u32 height = mipicsi->fmt.fmt.pix.height; + u64 offset = 0; + + for (i = 0; i < max_camsv_num; i++) + if (((mipicsi->link_reg_val >> i) & 0x01) == 0x01) { + offset = (u64)link_index * bytesperline * height; + mtk_mipicsi_fill_buffer(ch[i].camsv, + mipicsi->cam_buf[index].vb_dma_addr_phy + + offset); + link_index++; + } +} + static void mtk_mipicsi_vb2_queue(struct vb2_buffer *vb) { struct mtk_mipicsi_dev *mipicsi = vb2_get_drv_priv(vb->vb2_queue); @@ -546,6 +573,12 @@ static void mtk_mipicsi_vb2_queue(struct vb2_buffer *vb) list_add_tail(&(mipicsi->cam_buf[vb->index].queue), &(mipicsi->fb_list)); spin_unlock(&mipicsi->queue_lock); + + spin_lock(&mipicsi->irqlock); + if (!mipicsi->streamon) + mtk_mipicsi_write_camsv(mipicsi, vb->index, mipicsi->camsv_num); + + spin_unlock(&mipicsi->irqlock); } static void mtk_mipicsi_cmos_vf_enable(struct mtk_mipicsi_dev *mipicsi, @@ -875,6 +908,8 @@ static void mtk_mipicsi_irq_buf_process(struct mtk_mipicsi_dev *mipicsi) ++i; } + mtk_mipicsi_write_camsv(mipicsi, next, mipicsi->camsv_num); + /* * fb_list has one more buffer. Free the first buffer to user * and fill the second buffer to HW. -- 2.18.0