Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp5081330imu; Tue, 13 Nov 2018 00:27:40 -0800 (PST) X-Google-Smtp-Source: AJdET5cCuR4Pw/xz17iXgO3yHjn7DRceoExNz1/GV8UPLLrQ0jz7gtTZiXUfLh318QCkpIZsXH1h X-Received: by 2002:a17:902:ac93:: with SMTP id h19-v6mr3998720plr.245.1542097660484; Tue, 13 Nov 2018 00:27:40 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1542097660; cv=none; d=google.com; s=arc-20160816; b=wDFLom+MO4lNyc9vIdCLOvX4d9kjv9nKxu4xB3AMBlWmz/9JGvs0GMq4y0ChCbZbPO vn9wx8w3PUjjEYxftjIZV9DO95tTuswTNwpe81zGZDxUVZSnWnddiW4+tB1tSsRS7IrO qf+wFSoJzLMYNIUvuOrX0BlCXht2WrtSsbOY7PnB8mWsielK4pK5y0kHIyL52uuXL+JU L1e285nTBqFeny8lpv+HUMk+q9dqWs/TnkH3wXJ70m++kYs6muPXdjDE1AX5Mbn9qdN2 //SKJK+Jw2Li7B0ayegNPQLabbRp+b4HS4mkQH9PFCG5naF9xA6Y7P6DJ52hi9CyCjrd r/Mw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=mBahrvDhydviP6/sXDzlrSNT7/7UqWLlgbuR8gL8B4A=; b=YRvHOHY3gq+FRFlebhNJHR6BjXpKRQFGMt+Kwd8WyxpyXlCd2swb90eXnJqS9sQY7p Q7Z7hYeykno2OsKAsFH+LRPQ1Qocy/dvO56t3wiB6S/QU7SUWV57v6M6ivvSo4YqLkEI VhWYzl/ZufzWg4YyFaZVHETHuGsGy/GEEeALXgHf3+vHWf5cCWXoInaDzzsSqEsUcBB4 tM0L2NyJa1lnNAMvWx0UXRx62Ic8FFVOsj7oYWOLyXydzFwYT+9uJFUg07v3ysxi2n8b /Gp78+bUlIBRx4cvdHak9Xt3qOIxIwRP+N4nUBZXk+l41IaSpE1w+Nebo2qk+Ely76+O uHhw== 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 101-v6si22683145pld.398.2018.11.13.00.27.25; Tue, 13 Nov 2018 00:27:40 -0800 (PST) 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 S1731379AbeKMSVV (ORCPT + 99 others); Tue, 13 Nov 2018 13:21:21 -0500 Received: from mail.bootlin.com ([62.4.15.54]:40195 "EHLO mail.bootlin.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731345AbeKMSVV (ORCPT ); Tue, 13 Nov 2018 13:21:21 -0500 Received: by mail.bootlin.com (Postfix, from userid 110) id A6774207B0; Tue, 13 Nov 2018 09:24:18 +0100 (CET) X-Spam-Checker-Version: SpamAssassin 3.4.2 (2018-09-13) on mail.bootlin.com X-Spam-Level: X-Spam-Status: No, score=-1.0 required=5.0 tests=ALL_TRUSTED,SHORTCIRCUIT shortcircuit=ham autolearn=disabled version=3.4.2 Received: from localhost (aaubervilliers-681-1-30-49.w90-88.abo.wanadoo.fr [90.88.15.49]) by mail.bootlin.com (Postfix) with ESMTPSA id 727942039F; Tue, 13 Nov 2018 09:24:18 +0100 (CET) From: Maxime Ripard To: Hans Verkuil , Sakari Ailus , Mauro Carvalho Chehab Cc: Thomas Petazzoni , Laurent Pinchart , linux-media@vger.kernel.org, Andrzej Hajda , Chen-Yu Tsai , linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, devicetree@vger.kernel.org, Mark Rutland , Rob Herring , Frank Rowand , Maxime Ripard Subject: [PATCH 0/5] media: Allwinner A10 CSI support Date: Tue, 13 Nov 2018 09:24:12 +0100 Message-Id: X-Mailer: git-send-email 2.19.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi, Here is a series introducing the support for the A10 (and SoCs of the same generation) CMOS Sensor Interface (called CSI, not to be confused with MIPI-CSI, which isn't support by that IP). That interface is pretty straightforward, but the driver has a few issues that I wanted to bring up: * The only board I've been testing this with has an ov5640 sensor attached, which doesn't work with the upstream driver. Copying the Allwinner init sequence works though, and this is how it has been tested. Testing with a second sensor would allow to see if it's an issue on the CSI side or the sensor side. * When starting a capture, the last buffer to capture will fail due to double buffering being used, and we don't have a next buffer for the last frame. I'm not sure how to deal with that though. It seems like some drivers use a scratch buffer in such a case, some don't care, so I'm not sure which solution should be preferred. * We don't have support for the ISP at the moment, but this can be added eventually. * How to model the CSI module clock isn't really clear to me. It looks like it goes through the CSI controller and then is muxed to one of the CSI pin so that it can clock the sensor. I'm not quite sure how to model it, if it should be a clock, the CSI driver being a clock provider, or if the sensor should just use the module clock directly. Here is the v4l2-compliance output: v4l2-compliance SHA : 339d550e92ac15de8668f32d66d16f198137006c Driver Info: Driver name : sun4i_csi Card type : sun4i-csi Bus info : platform:1c09000.csi Driver version: 4.19.0 Capabilities : 0x84201000 Video Capture Multiplanar Streaming Extended Pix Format Device Capabilities Device Caps : 0x04201000 Video Capture Multiplanar Streaming Extended Pix Format Compliance test for device /dev/video0 (not using libv4l2): Required ioctls: test VIDIOC_QUERYCAP: OK Allow for multiple opens: test second video open: OK test VIDIOC_QUERYCAP: OK test VIDIOC_G/S_PRIORITY: OK test for unlimited opens: OK Debug ioctls: test VIDIOC_DBG_G/S_REGISTER: OK (Not Supported) test VIDIOC_LOG_STATUS: OK (Not Supported) Input ioctls: test VIDIOC_G/S_TUNER/ENUM_FREQ_BANDS: OK (Not Supported) test VIDIOC_G/S_FREQUENCY: OK (Not Supported) test VIDIOC_S_HW_FREQ_SEEK: OK (Not Supported) test VIDIOC_ENUMAUDIO: OK (Not Supported) test VIDIOC_G/S/ENUMINPUT: OK test VIDIOC_G/S_AUDIO: OK (Not Supported) Inputs: 1 Audio Inputs: 0 Tuners: 0 Output ioctls: test VIDIOC_G/S_MODULATOR: OK (Not Supported) test VIDIOC_G/S_FREQUENCY: OK (Not Supported) test VIDIOC_ENUMAUDOUT: OK (Not Supported) test VIDIOC_G/S/ENUMOUTPUT: OK (Not Supported) test VIDIOC_G/S_AUDOUT: OK (Not Supported) Outputs: 0 Audio Outputs: 0 Modulators: 0 Input/Output configuration ioctls: test VIDIOC_ENUM/G/S/QUERY_STD: OK (Not Supported) test VIDIOC_ENUM/G/S/QUERY_DV_TIMINGS: OK (Not Supported) test VIDIOC_DV_TIMINGS_CAP: OK (Not Supported) test VIDIOC_G/S_EDID: OK (Not Supported) Test input 0: Control ioctls: test VIDIOC_QUERY_EXT_CTRL/QUERYMENU: OK (Not Supported) test VIDIOC_QUERYCTRL: OK (Not Supported) test VIDIOC_G/S_CTRL: OK (Not Supported) test VIDIOC_G/S/TRY_EXT_CTRLS: OK (Not Supported) test VIDIOC_(UN)SUBSCRIBE_EVENT/DQEVENT: OK (Not Supported) test VIDIOC_G/S_JPEGCOMP: OK (Not Supported) Standard Controls: 0 Private Controls: 0 Format ioctls: test VIDIOC_ENUM_FMT/FRAMESIZES/FRAMEINTERVALS: OK test VIDIOC_G/S_PARM: OK (Not Supported) test VIDIOC_G_FBUF: OK (Not Supported) test VIDIOC_G_FMT: OK test VIDIOC_TRY_FMT: OK test VIDIOC_S_FMT: OK test VIDIOC_G_SLICED_VBI_CAP: OK (Not Supported) test Cropping: OK (Not Supported) test Composing: OK (Not Supported) test Scaling: OK Codec ioctls: test VIDIOC_(TRY_)ENCODER_CMD: OK (Not Supported) test VIDIOC_G_ENC_INDEX: OK (Not Supported) test VIDIOC_(TRY_)DECODER_CMD: OK (Not Supported) Buffer ioctls: test VIDIOC_REQBUFS/CREATE_BUFS/QUERYBUF: OK test VIDIOC_EXPBUF: OK Test input 0: Total: 43, Succeeded: 43, Failed: 0, Warnings: 0 Let me know what you think, Maxime Maxime Ripard (5): dt-bindings: media: Add Allwinner A10 CSI binding media: sunxi: Refactor the Makefile and Kconfig media: sunxi: Add A10 CSI driver ARM: dts: sun7i: Add CSI0 controller DO NOT MERGE: ARM: dts: bananapi: Add Camera support Documentation/devicetree/bindings/media/sun4i-csi.txt | 71 ++- arch/arm/boot/dts/sun7i-a20-bananapi.dts | 98 +++- arch/arm/boot/dts/sun7i-a20.dtsi | 13 +- drivers/media/platform/Kconfig | 2 +- drivers/media/platform/Makefile | 2 +- drivers/media/platform/sunxi/Kconfig | 2 +- drivers/media/platform/sunxi/Makefile | 2 +- drivers/media/platform/sunxi/sun4i-csi/Kconfig | 12 +- drivers/media/platform/sunxi/sun4i-csi/Makefile | 5 +- drivers/media/platform/sunxi/sun4i-csi/sun4i_csi.c | 275 ++++++++- drivers/media/platform/sunxi/sun4i-csi/sun4i_csi.h | 137 ++++- drivers/media/platform/sunxi/sun4i-csi/sun4i_dma.c | 383 +++++++++++- drivers/media/platform/sunxi/sun4i-csi/sun4i_v4l2.c | 287 ++++++++- 13 files changed, 1287 insertions(+), 2 deletions(-) create mode 100644 Documentation/devicetree/bindings/media/sun4i-csi.txt create mode 100644 drivers/media/platform/sunxi/Kconfig create mode 100644 drivers/media/platform/sunxi/Makefile create mode 100644 drivers/media/platform/sunxi/sun4i-csi/Kconfig create mode 100644 drivers/media/platform/sunxi/sun4i-csi/Makefile create mode 100644 drivers/media/platform/sunxi/sun4i-csi/sun4i_csi.c create mode 100644 drivers/media/platform/sunxi/sun4i-csi/sun4i_csi.h create mode 100644 drivers/media/platform/sunxi/sun4i-csi/sun4i_dma.c create mode 100644 drivers/media/platform/sunxi/sun4i-csi/sun4i_v4l2.c base-commit: 94517eaa3d43005472864615dfd17f1ef6ca3935 -- git-series 0.9.1