devicetree.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH v3 0/2] [media] atmel-isc: add driver for Atmel ISC
@ 2016-05-31  6:58 Songjun Wu
  2016-05-31  6:58 ` [PATCH v3 2/2] [media] atmel-isc: DT binding for Image Sensor Controller driver Songjun Wu
       [not found] ` <1464677903-28412-1-git-send-email-songjun.wu-AIFe0yeh4nAAvxtiuMwx3w@public.gmane.org>
  0 siblings, 2 replies; 7+ messages in thread
From: Songjun Wu @ 2016-05-31  6:58 UTC (permalink / raw)
  To: g.liakhovetski-Mmb7MZpHnFY,
	laurent.pinchart-ryLnwIuWjnjg/C1BVhZhaw,
	nicolas.ferre-AIFe0yeh4nAAvxtiuMwx3w, robh-DgEjT+Ai2ygdnm+yROfE0A
  Cc: linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r, Songjun Wu,
	Fabien Dessenne, Ian Campbell, devicetree-u79uwXL29TY76Z2rM5mHXA,
	Mauro Carvalho Chehab, Richard Röjfors, Benoit Parrot,
	Kumar Gala, linux-kernel-u79uwXL29TY76Z2rM5mHXA, Mikhail Ulyanov,
	Sudip Mukherjee, Rob Herring, Pawel Moll, Peter Griffin,
	Geert Uytterhoeven, Hans Verkuil, Mark Rutland,
	linux-media-u79uwXL29TY76Z2rM5mHXA, Simon Horman

The Image Sensor Controller driver includes two parts.
1) Driver code to implement the ISC function.
2) Device tree binding documentation, it describes how
   to add the ISC in device tree.

Changes in v3:
- Add pm runtime feature.
- Modify the isc clock code since the dt is changed.
- Remove the 'atmel,sensor-preferred'.
- Modify the isc clock node according to the Rob's remarks.

Changes in v2:
- Add "depends on COMMON_CLK" and "VIDEO_V4L2_SUBDEV_API"
  in Kconfig file.
- Correct typos and coding style according to Laurent's remarks.
- Delete the loop while in 'isc_clk_enable' function.
- Replace 'hsync_active', 'vsync_active' and 'pclk_sample'
  with 'pfe_cfg0' in struct isc_subdev_entity.
- Add the code to support VIDIOC_CREATE_BUFS in
  'isc_queue_setup' function.
- Invoke isc_config to configure register in
  'isc_start_streaming' function.
- Add the struct completion 'comp' to synchronize with
  the frame end interrupt in 'isc_stop_streaming' function.
- Check the return value of the clk_prepare_enable
  in 'isc_open' function.
- Set the default format in 'isc_open' function.
- Add an exit condition in the loop while in 'isc_config'.
- Delete the hardware setup operation in 'isc_set_format'.
- Refuse format modification during streaming
  in 'isc_s_fmt_vid_cap' function.
- Invoke v4l2_subdev_alloc_pad_config to allocate and
  initialize the pad config in 'isc_async_complete' function.
- Remove the '.owner  = THIS_MODULE,' in atmel_isc_driver.
- Replace the module_platform_driver_probe() with
  module_platform_driver().
- Remove the unit address of the endpoint.
- Add the unit address to the clock node.
- Avoid using underscores in node names.
- Drop the "0x" in the unit address of the i2c node.
- Modify the description of 'atmel,sensor-preferred'.
- Add the description for the ISC internal clock.

Songjun Wu (2):
  [media] atmel-isc: add the Image Sensor Controller code
  [media] atmel-isc: DT binding for Image Sensor Controller driver

 .../devicetree/bindings/media/atmel-isc.txt        |   88 ++
 drivers/media/platform/Kconfig                     |    1 +
 drivers/media/platform/Makefile                    |    2 +
 drivers/media/platform/atmel/Kconfig               |    9 +
 drivers/media/platform/atmel/Makefile              |    1 +
 drivers/media/platform/atmel/atmel-isc-regs.h      |  276 ++++
 drivers/media/platform/atmel/atmel-isc.c           | 1610 ++++++++++++++++++++
 7 files changed, 1987 insertions(+)
 create mode 100644 Documentation/devicetree/bindings/media/atmel-isc.txt
 create mode 100644 drivers/media/platform/atmel/Kconfig
 create mode 100644 drivers/media/platform/atmel/Makefile
 create mode 100644 drivers/media/platform/atmel/atmel-isc-regs.h
 create mode 100644 drivers/media/platform/atmel/atmel-isc.c

-- 
2.7.4

--
To unsubscribe from this list: send the line "unsubscribe devicetree" in
the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

^ permalink raw reply	[flat|nested] 7+ messages in thread

* [PATCH v3 2/2] [media] atmel-isc: DT binding for Image Sensor Controller driver
  2016-05-31  6:58 [PATCH v3 0/2] [media] atmel-isc: add driver for Atmel ISC Songjun Wu
@ 2016-05-31  6:58 ` Songjun Wu
  2016-06-02 23:16   ` Rob Herring
       [not found] ` <1464677903-28412-1-git-send-email-songjun.wu-AIFe0yeh4nAAvxtiuMwx3w@public.gmane.org>
  1 sibling, 1 reply; 7+ messages in thread
From: Songjun Wu @ 2016-05-31  6:58 UTC (permalink / raw)
  To: g.liakhovetski, laurent.pinchart, nicolas.ferre, robh
  Cc: linux-arm-kernel, Songjun Wu, devicetree, Kumar Gala,
	linux-kernel, Ian Campbell, Rob Herring, Pawel Moll, Mark Rutland

DT binding documentation for ISC driver.

Signed-off-by: Songjun Wu <songjun.wu@atmel.com>
---

Changes in v3:
- Remove the 'atmel,sensor-preferred'.
- Modify the isc clock node according to the Rob's remarks.

Changes in v2:
- Remove the unit address of the endpoint.
- Add the unit address to the clock node.
- Avoid using underscores in node names.
- Drop the "0x" in the unit address of the i2c node.
- Modify the description of 'atmel,sensor-preferred'.
- Add the description for the ISC internal clock.

 .../devicetree/bindings/media/atmel-isc.txt        | 88 ++++++++++++++++++++++
 1 file changed, 88 insertions(+)
 create mode 100644 Documentation/devicetree/bindings/media/atmel-isc.txt

diff --git a/Documentation/devicetree/bindings/media/atmel-isc.txt b/Documentation/devicetree/bindings/media/atmel-isc.txt
new file mode 100644
index 0000000..2ae1d60
--- /dev/null
+++ b/Documentation/devicetree/bindings/media/atmel-isc.txt
@@ -0,0 +1,88 @@
+Atmel Image Sensor Controller (ISC)
+----------------------------------------------
+
+Required properties for ISC:
+- compatible
+	Must be "atmel,sama5d2-isc"
+- reg
+	Physical base address and length of the registers set for the device;
+- interrupts
+	Should contain IRQ line for the ISI;
+- clocks
+	List of clock specifiers, corresponding to entries in
+	the clock-names property;
+	Please refer to clock-bindings.txt.
+- clock-names
+	Required elements: "hclock", "ispck".
+- pinctrl-names, pinctrl-0
+	Please refer to pinctrl-bindings.txt.
+- isc-ispck
+	The clock for the ISC digital pipeline.
+	- compatible
+		Must be "atmel,sama5d2-isc-ispck".
+	- clock-cells
+		From common clock binding; should be set to 0.
+	- clocks
+		The clock source phandles.
+- isc-mck
+	The clock for the image sensor.
+	- compatible
+		Must be "atmel,sama5d2-isc-mck".
+	- clock-cells
+		From common clock binding; should be set to 0.
+	- clocks
+		The clock source phandles.
+
+ISC supports a single port node with parallel bus. It should contain one
+'port' child node with child 'endpoint' node. Please refer to the bindings
+defined in Documentation/devicetree/bindings/media/video-interfaces.txt.
+
+Example:
+isc: isc@f0008000 {
+	compatible = "atmel,sama5d2-isc";
+	reg = <0xf0008000 0x4000>;
+	interrupts = <46 IRQ_TYPE_LEVEL_HIGH 5>;
+	clocks = <&isc_clk>, <&isc_ispck>;
+	clock-names = "hclock", "ispck";
+
+	port {
+		#address-cells = <1>;
+		#size-cells = <0>;
+
+		isc_0: endpoint {
+			remote-endpoint = <&ov7740_0>;
+			hsync-active = <1>;
+			vsync-active = <0>;
+			pclk-sample = <1>;
+		};
+	};
+
+	isc_ispck: isc-ispck@0 {
+		compatible = "atmel,sama5d2-isc-ispck";
+		#clock-cells = <0>;
+		clocks = <&isc_clk>, <&iscck>;
+	};
+
+	isc_mck: isc-mck@1 {
+		compatible = "atmel,sama5d2-isc-mck";
+		#clock-cells = <0>;
+		clocks = <&isc_clk>, <&iscck>, <&isc_gclk>;
+	};
+};
+
+i2c1: i2c@fc028000 {
+	ov7740: camera@21 {
+	compatible = "ovti,ov7740";
+	reg = <0x21>;
+
+	clocks = <&isc_mck>;
+	clock-names = "xvclk";
+	assigned-clocks = <&isc_mck>;
+	assigned-clock-rates = <24000000>;
+
+	port {
+		ov7740_0: endpoint {
+			remote-endpoint = <&isc_0>;
+		};
+	};
+};
-- 
2.7.4

^ permalink raw reply related	[flat|nested] 7+ messages in thread

* Re: [PATCH v3 0/2] [media] atmel-isc: add driver for Atmel ISC
       [not found] ` <1464677903-28412-1-git-send-email-songjun.wu-AIFe0yeh4nAAvxtiuMwx3w@public.gmane.org>
@ 2016-05-31  7:17   ` Geert Uytterhoeven
  0 siblings, 0 replies; 7+ messages in thread
From: Geert Uytterhoeven @ 2016-05-31  7:17 UTC (permalink / raw)
  To: Songjun Wu
  Cc: Guennadi Liakhovetski, Laurent Pinchart, Nicolas Ferre,
	Rob Herring,
	linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r@public.gmane.org,
	Fabien Dessenne, Ian Campbell,
	devicetree-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
	Mauro Carvalho Chehab, Richard Röjfors, Benoit Parrot,
	Kumar Gala, linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
	Mikhail Ulyanov, Sudip Mukherjee, Rob Herring, Pawel Moll,
	Peter Griffin, Hans Verkuil

Hi Songjun,

On Tue, May 31, 2016 at 8:58 AM, Songjun Wu <songjun.wu-AIFe0yeh4nAAvxtiuMwx3w@public.gmane.org> wrote:
> The Image Sensor Controller driver includes two parts.
> 1) Driver code to implement the ISC function.
> 2) Device tree binding documentation, it describes how
>    to add the ISC in device tree.

Please reduce the CC list. Not everyone who ever touched a line in the
files you modified is working on media or atmel devices.

get_maintainer.pl gives hints, not exact lists of people.

Thanks!

Gr{oetje,eeting}s,

                        Geert

--
Geert Uytterhoeven -- There's lots of Linux beyond ia32 -- geert-Td1EMuHUCqxL1ZNQvxDV9g@public.gmane.org

In personal conversations with technical people, I call myself a hacker. But
when I'm talking to journalists I just say "programmer" or something like that.
                                -- Linus Torvalds
--
To unsubscribe from this list: send the line "unsubscribe devicetree" in
the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [PATCH v3 2/2] [media] atmel-isc: DT binding for Image Sensor Controller driver
  2016-05-31  6:58 ` [PATCH v3 2/2] [media] atmel-isc: DT binding for Image Sensor Controller driver Songjun Wu
@ 2016-06-02 23:16   ` Rob Herring
  2016-06-03 11:10     ` Boris Brezillon
  2016-06-06  6:42     ` Wu, Songjun
  0 siblings, 2 replies; 7+ messages in thread
From: Rob Herring @ 2016-06-02 23:16 UTC (permalink / raw)
  To: Songjun Wu
  Cc: g.liakhovetski, laurent.pinchart, nicolas.ferre, linux-arm-kernel,
	devicetree, Kumar Gala, linux-kernel, Ian Campbell, Pawel Moll,
	Mark Rutland

On Tue, May 31, 2016 at 02:58:23PM +0800, Songjun Wu wrote:
> DT binding documentation for ISC driver.
> 
> Signed-off-by: Songjun Wu <songjun.wu@atmel.com>
> ---
> 
> Changes in v3:
> - Remove the 'atmel,sensor-preferred'.
> - Modify the isc clock node according to the Rob's remarks.
> 
> Changes in v2:
> - Remove the unit address of the endpoint.
> - Add the unit address to the clock node.
> - Avoid using underscores in node names.
> - Drop the "0x" in the unit address of the i2c node.
> - Modify the description of 'atmel,sensor-preferred'.
> - Add the description for the ISC internal clock.
> 
>  .../devicetree/bindings/media/atmel-isc.txt        | 88 ++++++++++++++++++++++
>  1 file changed, 88 insertions(+)
>  create mode 100644 Documentation/devicetree/bindings/media/atmel-isc.txt
> 
> diff --git a/Documentation/devicetree/bindings/media/atmel-isc.txt b/Documentation/devicetree/bindings/media/atmel-isc.txt
> new file mode 100644
> index 0000000..2ae1d60
> --- /dev/null
> +++ b/Documentation/devicetree/bindings/media/atmel-isc.txt
> @@ -0,0 +1,88 @@
> +Atmel Image Sensor Controller (ISC)
> +----------------------------------------------
> +
> +Required properties for ISC:
> +- compatible
> +	Must be "atmel,sama5d2-isc"
> +- reg
> +	Physical base address and length of the registers set for the device;
> +- interrupts
> +	Should contain IRQ line for the ISI;
> +- clocks
> +	List of clock specifiers, corresponding to entries in
> +	the clock-names property;
> +	Please refer to clock-bindings.txt.
> +- clock-names
> +	Required elements: "hclock", "ispck".
> +- pinctrl-names, pinctrl-0
> +	Please refer to pinctrl-bindings.txt.
> +- isc-ispck
> +	The clock for the ISC digital pipeline.
> +	- compatible
> +		Must be "atmel,sama5d2-isc-ispck".
> +	- clock-cells
> +		From common clock binding; should be set to 0.
> +	- clocks
> +		The clock source phandles.
> +- isc-mck
> +	The clock for the image sensor.
> +	- compatible
> +		Must be "atmel,sama5d2-isc-mck".
> +	- clock-cells
> +		From common clock binding; should be set to 0.
> +	- clocks
> +		The clock source phandles.
> +
> +ISC supports a single port node with parallel bus. It should contain one
> +'port' child node with child 'endpoint' node. Please refer to the bindings
> +defined in Documentation/devicetree/bindings/media/video-interfaces.txt.
> +
> +Example:
> +isc: isc@f0008000 {
> +	compatible = "atmel,sama5d2-isc";
> +	reg = <0xf0008000 0x4000>;
> +	interrupts = <46 IRQ_TYPE_LEVEL_HIGH 5>;
> +	clocks = <&isc_clk>, <&isc_ispck>;
> +	clock-names = "hclock", "ispck";
> +
> +	port {
> +		#address-cells = <1>;
> +		#size-cells = <0>;
> +
> +		isc_0: endpoint {
> +			remote-endpoint = <&ov7740_0>;
> +			hsync-active = <1>;
> +			vsync-active = <0>;
> +			pclk-sample = <1>;
> +		};
> +	};
> +
> +	isc_ispck: isc-ispck@0 {

Drop the unit-address. You should only have one if you have a reg 
property.

> +		compatible = "atmel,sama5d2-isc-ispck";
> +		#clock-cells = <0>;
> +		clocks = <&isc_clk>, <&iscck>;
> +	};
> +
> +	isc_mck: isc-mck@1 {

ditto.

I still think these should be implied by atmel,sama5d2-isc and not in 
DT. The fact that you don't have any registers for them pretty much 
indicates that. It is also strange that isc-ispck is used by isc. If 
that is the only user, there is certainly no need to put it in DT.


> +		compatible = "atmel,sama5d2-isc-mck";
> +		#clock-cells = <0>;
> +		clocks = <&isc_clk>, <&iscck>, <&isc_gclk>;
> +	};
> +};
> +
> +i2c1: i2c@fc028000 {
> +	ov7740: camera@21 {
> +	compatible = "ovti,ov7740";
> +	reg = <0x21>;
> +
> +	clocks = <&isc_mck>;
> +	clock-names = "xvclk";
> +	assigned-clocks = <&isc_mck>;
> +	assigned-clock-rates = <24000000>;
> +
> +	port {
> +		ov7740_0: endpoint {
> +			remote-endpoint = <&isc_0>;
> +		};
> +	};
> +};
> -- 
> 2.7.4
> 

^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [PATCH v3 2/2] [media] atmel-isc: DT binding for Image Sensor Controller driver
  2016-06-02 23:16   ` Rob Herring
@ 2016-06-03 11:10     ` Boris Brezillon
  2016-06-06  6:44       ` Wu, Songjun
  2016-06-06  6:42     ` Wu, Songjun
  1 sibling, 1 reply; 7+ messages in thread
From: Boris Brezillon @ 2016-06-03 11:10 UTC (permalink / raw)
  To: Rob Herring, Songjun Wu
  Cc: Mark Rutland, devicetree, Pawel Moll, Ian Campbell, nicolas.ferre,
	linux-kernel, laurent.pinchart, Kumar Gala, g.liakhovetski,
	linux-arm-kernel

On Thu, 2 Jun 2016 18:16:09 -0500
Rob Herring <robh@kernel.org> wrote:

> On Tue, May 31, 2016 at 02:58:23PM +0800, Songjun Wu wrote:
> > DT binding documentation for ISC driver.
> > 
> > Signed-off-by: Songjun Wu <songjun.wu@atmel.com>
> > ---
> > 
> > Changes in v3:
> > - Remove the 'atmel,sensor-preferred'.
> > - Modify the isc clock node according to the Rob's remarks.
> > 
> > Changes in v2:
> > - Remove the unit address of the endpoint.
> > - Add the unit address to the clock node.
> > - Avoid using underscores in node names.
> > - Drop the "0x" in the unit address of the i2c node.
> > - Modify the description of 'atmel,sensor-preferred'.
> > - Add the description for the ISC internal clock.
> > 
> >  .../devicetree/bindings/media/atmel-isc.txt        | 88 ++++++++++++++++++++++
> >  1 file changed, 88 insertions(+)
> >  create mode 100644 Documentation/devicetree/bindings/media/atmel-isc.txt
> > 
> > diff --git a/Documentation/devicetree/bindings/media/atmel-isc.txt b/Documentation/devicetree/bindings/media/atmel-isc.txt
> > new file mode 100644
> > index 0000000..2ae1d60
> > --- /dev/null
> > +++ b/Documentation/devicetree/bindings/media/atmel-isc.txt
> > @@ -0,0 +1,88 @@
> > +Atmel Image Sensor Controller (ISC)
> > +----------------------------------------------
> > +
> > +Required properties for ISC:
> > +- compatible
> > +	Must be "atmel,sama5d2-isc"
> > +- reg
> > +	Physical base address and length of the registers set for the device;
> > +- interrupts
> > +	Should contain IRQ line for the ISI;
> > +- clocks
> > +	List of clock specifiers, corresponding to entries in
> > +	the clock-names property;
> > +	Please refer to clock-bindings.txt.
> > +- clock-names
> > +	Required elements: "hclock", "ispck".
> > +- pinctrl-names, pinctrl-0
> > +	Please refer to pinctrl-bindings.txt.
> > +- isc-ispck
> > +	The clock for the ISC digital pipeline.
> > +	- compatible
> > +		Must be "atmel,sama5d2-isc-ispck".
> > +	- clock-cells
> > +		From common clock binding; should be set to 0.
> > +	- clocks
> > +		The clock source phandles.
> > +- isc-mck
> > +	The clock for the image sensor.
> > +	- compatible
> > +		Must be "atmel,sama5d2-isc-mck".
> > +	- clock-cells
> > +		From common clock binding; should be set to 0.
> > +	- clocks
> > +		The clock source phandles.
> > +
> > +ISC supports a single port node with parallel bus. It should contain one
> > +'port' child node with child 'endpoint' node. Please refer to the bindings
> > +defined in Documentation/devicetree/bindings/media/video-interfaces.txt.
> > +
> > +Example:
> > +isc: isc@f0008000 {
> > +	compatible = "atmel,sama5d2-isc";
> > +	reg = <0xf0008000 0x4000>;
> > +	interrupts = <46 IRQ_TYPE_LEVEL_HIGH 5>;
> > +	clocks = <&isc_clk>, <&isc_ispck>;
> > +	clock-names = "hclock", "ispck";
> > +
> > +	port {
> > +		#address-cells = <1>;
> > +		#size-cells = <0>;
> > +
> > +		isc_0: endpoint {
> > +			remote-endpoint = <&ov7740_0>;
> > +			hsync-active = <1>;
> > +			vsync-active = <0>;
> > +			pclk-sample = <1>;
> > +		};
> > +	};
> > +
> > +	isc_ispck: isc-ispck@0 {  
> 
> Drop the unit-address. You should only have one if you have a reg 
> property.
> 
> > +		compatible = "atmel,sama5d2-isc-ispck";
> > +		#clock-cells = <0>;
> > +		clocks = <&isc_clk>, <&iscck>;
> > +	};
> > +
> > +	isc_mck: isc-mck@1 {  
> 
> ditto.
> 
> I still think these should be implied by atmel,sama5d2-isc and not in 
> DT. The fact that you don't have any registers for them pretty much 
> indicates that. It is also strange that isc-ispck is used by isc. If 
> that is the only user, there is certainly no need to put it in DT.

I had a look at the block diagram, and it seems you are partially right.
The only clock that is really exported by the ISC is isc_mck (isc_pck is
not).
So I'd suggest dropping these clk sub-nodes, putting the #clock-cells,
and clock-names properties in the isc node, and then referencing the
isc node in you i2c device.

isc: isc@f0008000 {
	compatible = "atmel,sama5d2-isc";
	reg = <0xf0008000 0x4000>;
	interrupts = <46 IRQ_TYPE_LEVEL_HIGH 5>;
	clocks = <&isc_clk>, <&isc_ispck>;
	clock-names = "hclock", "ispck";
	#clock-cells = <0>;
	clock-output-names = "isc-mck";
};

i2c1: i2c@fc028000 {
	/* ... */
	ov7740: camera@21 {
		/* ... */
		clocks = <&isc>;
		clock-names = "xvclk";
	}
};

If I'm wrong and the ISC IP is really exposing several clks, you just
have to change #clock-cells to 1, and use clocks = <&isc X>; in the i2c
device node.

Rob, Songjun, would you agree on this representation?

> 
> 
> > +		compatible = "atmel,sama5d2-isc-mck";
> > +		#clock-cells = <0>;
> > +		clocks = <&isc_clk>, <&iscck>, <&isc_gclk>;
> > +	};
> > +};
> > +
> > +i2c1: i2c@fc028000 {
> > +	ov7740: camera@21 {
> > +	compatible = "ovti,ov7740";
> > +	reg = <0x21>;
> > +
> > +	clocks = <&isc_mck>;
> > +	clock-names = "xvclk";
> > +	assigned-clocks = <&isc_mck>;
> > +	assigned-clock-rates = <24000000>;
> > +
> > +	port {
> > +		ov7740_0: endpoint {
> > +			remote-endpoint = <&isc_0>;
> > +		};
> > +	};
> > +};
> > -- 
> > 2.7.4
> >   
> 
> _______________________________________________
> linux-arm-kernel mailing list
> linux-arm-kernel@lists.infradead.org
> http://lists.infradead.org/mailman/listinfo/linux-arm-kernel



-- 
Boris Brezillon, Free Electrons
Embedded Linux and Kernel engineering
http://free-electrons.com

^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [PATCH v3 2/2] [media] atmel-isc: DT binding for Image Sensor Controller driver
  2016-06-02 23:16   ` Rob Herring
  2016-06-03 11:10     ` Boris Brezillon
@ 2016-06-06  6:42     ` Wu, Songjun
  1 sibling, 0 replies; 7+ messages in thread
From: Wu, Songjun @ 2016-06-06  6:42 UTC (permalink / raw)
  To: Rob Herring
  Cc: g.liakhovetski-Mmb7MZpHnFY,
	laurent.pinchart-ryLnwIuWjnjg/C1BVhZhaw,
	nicolas.ferre-AIFe0yeh4nAAvxtiuMwx3w,
	linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r,
	devicetree-u79uwXL29TY76Z2rM5mHXA, Kumar Gala,
	linux-kernel-u79uwXL29TY76Z2rM5mHXA, Ian Campbell, Pawel Moll,
	Mark Rutland

Hi Rob,

Thank you for your comments.

On 6/3/2016 07:16, Rob Herring wrote:
> On Tue, May 31, 2016 at 02:58:23PM +0800, Songjun Wu wrote:
>> DT binding documentation for ISC driver.
>>
>> Signed-off-by: Songjun Wu <songjun.wu-AIFe0yeh4nAAvxtiuMwx3w@public.gmane.org>
>> ---
>>
>> Changes in v3:
>> - Remove the 'atmel,sensor-preferred'.
>> - Modify the isc clock node according to the Rob's remarks.
>>
>> Changes in v2:
>> - Remove the unit address of the endpoint.
>> - Add the unit address to the clock node.
>> - Avoid using underscores in node names.
>> - Drop the "0x" in the unit address of the i2c node.
>> - Modify the description of 'atmel,sensor-preferred'.
>> - Add the description for the ISC internal clock.
>>
>>  .../devicetree/bindings/media/atmel-isc.txt        | 88 ++++++++++++++++++++++
>>  1 file changed, 88 insertions(+)
>>  create mode 100644 Documentation/devicetree/bindings/media/atmel-isc.txt
>>
>> diff --git a/Documentation/devicetree/bindings/media/atmel-isc.txt b/Documentation/devicetree/bindings/media/atmel-isc.txt
>> new file mode 100644
>> index 0000000..2ae1d60
>> --- /dev/null
>> +++ b/Documentation/devicetree/bindings/media/atmel-isc.txt
>> @@ -0,0 +1,88 @@
>> +Atmel Image Sensor Controller (ISC)
>> +----------------------------------------------
>> +
>> +Required properties for ISC:
>> +- compatible
>> +	Must be "atmel,sama5d2-isc"
>> +- reg
>> +	Physical base address and length of the registers set for the device;
>> +- interrupts
>> +	Should contain IRQ line for the ISI;
>> +- clocks
>> +	List of clock specifiers, corresponding to entries in
>> +	the clock-names property;
>> +	Please refer to clock-bindings.txt.
>> +- clock-names
>> +	Required elements: "hclock", "ispck".
>> +- pinctrl-names, pinctrl-0
>> +	Please refer to pinctrl-bindings.txt.
>> +- isc-ispck
>> +	The clock for the ISC digital pipeline.
>> +	- compatible
>> +		Must be "atmel,sama5d2-isc-ispck".
>> +	- clock-cells
>> +		From common clock binding; should be set to 0.
>> +	- clocks
>> +		The clock source phandles.
>> +- isc-mck
>> +	The clock for the image sensor.
>> +	- compatible
>> +		Must be "atmel,sama5d2-isc-mck".
>> +	- clock-cells
>> +		From common clock binding; should be set to 0.
>> +	- clocks
>> +		The clock source phandles.
>> +
>> +ISC supports a single port node with parallel bus. It should contain one
>> +'port' child node with child 'endpoint' node. Please refer to the bindings
>> +defined in Documentation/devicetree/bindings/media/video-interfaces.txt.
>> +
>> +Example:
>> +isc: isc@f0008000 {
>> +	compatible = "atmel,sama5d2-isc";
>> +	reg = <0xf0008000 0x4000>;
>> +	interrupts = <46 IRQ_TYPE_LEVEL_HIGH 5>;
>> +	clocks = <&isc_clk>, <&isc_ispck>;
>> +	clock-names = "hclock", "ispck";
>> +
>> +	port {
>> +		#address-cells = <1>;
>> +		#size-cells = <0>;
>> +
>> +		isc_0: endpoint {
>> +			remote-endpoint = <&ov7740_0>;
>> +			hsync-active = <1>;
>> +			vsync-active = <0>;
>> +			pclk-sample = <1>;
>> +		};
>> +	};
>> +
>> +	isc_ispck: isc-ispck@0 {
>
> Drop the unit-address. You should only have one if you have a reg
> property.
>
Accept. Thank you.

>> +		compatible = "atmel,sama5d2-isc-ispck";
>> +		#clock-cells = <0>;
>> +		clocks = <&isc_clk>, <&iscck>;
>> +	};
>> +
>> +	isc_mck: isc-mck@1 {
>
> ditto.
>
> I still think these should be implied by atmel,sama5d2-isc and not in
> DT. The fact that you don't have any registers for them pretty much
> indicates that. It is also strange that isc-ispck is used by isc. If
> that is the only user, there is certainly no need to put it in DT.
>
The isc-ispck in only used by isc, it can be removed from DT.
Thank you.
>
>> +		compatible = "atmel,sama5d2-isc-mck";
>> +		#clock-cells = <0>;
>> +		clocks = <&isc_clk>, <&iscck>, <&isc_gclk>;
>> +	};
>> +};
>> +
>> +i2c1: i2c@fc028000 {
>> +	ov7740: camera@21 {
>> +	compatible = "ovti,ov7740";
>> +	reg = <0x21>;
>> +
>> +	clocks = <&isc_mck>;
>> +	clock-names = "xvclk";
>> +	assigned-clocks = <&isc_mck>;
>> +	assigned-clock-rates = <24000000>;
>> +
>> +	port {
>> +		ov7740_0: endpoint {
>> +			remote-endpoint = <&isc_0>;
>> +		};
>> +	};
>> +};
>> --
>> 2.7.4
>>
--
To unsubscribe from this list: send the line "unsubscribe devicetree" in
the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

^ permalink raw reply	[flat|nested] 7+ messages in thread

* Re: [PATCH v3 2/2] [media] atmel-isc: DT binding for Image Sensor Controller driver
  2016-06-03 11:10     ` Boris Brezillon
@ 2016-06-06  6:44       ` Wu, Songjun
  0 siblings, 0 replies; 7+ messages in thread
From: Wu, Songjun @ 2016-06-06  6:44 UTC (permalink / raw)
  To: Boris Brezillon, Rob Herring
  Cc: Mark Rutland, devicetree, Pawel Moll, Ian Campbell, nicolas.ferre,
	linux-kernel, laurent.pinchart, Kumar Gala, g.liakhovetski,
	linux-arm-kernel



On 6/3/2016 19:10, Boris Brezillon wrote:
> On Thu, 2 Jun 2016 18:16:09 -0500
> Rob Herring <robh@kernel.org> wrote:
>
>> On Tue, May 31, 2016 at 02:58:23PM +0800, Songjun Wu wrote:
>>> DT binding documentation for ISC driver.
>>>
>>> Signed-off-by: Songjun Wu <songjun.wu@atmel.com>
>>> ---
>>>
>>> Changes in v3:
>>> - Remove the 'atmel,sensor-preferred'.
>>> - Modify the isc clock node according to the Rob's remarks.
>>>
>>> Changes in v2:
>>> - Remove the unit address of the endpoint.
>>> - Add the unit address to the clock node.
>>> - Avoid using underscores in node names.
>>> - Drop the "0x" in the unit address of the i2c node.
>>> - Modify the description of 'atmel,sensor-preferred'.
>>> - Add the description for the ISC internal clock.
>>>
>>>  .../devicetree/bindings/media/atmel-isc.txt        | 88 ++++++++++++++++++++++
>>>  1 file changed, 88 insertions(+)
>>>  create mode 100644 Documentation/devicetree/bindings/media/atmel-isc.txt
>>>
>>> diff --git a/Documentation/devicetree/bindings/media/atmel-isc.txt b/Documentation/devicetree/bindings/media/atmel-isc.txt
>>> new file mode 100644
>>> index 0000000..2ae1d60
>>> --- /dev/null
>>> +++ b/Documentation/devicetree/bindings/media/atmel-isc.txt
>>> @@ -0,0 +1,88 @@
>>> +Atmel Image Sensor Controller (ISC)
>>> +----------------------------------------------
>>> +
>>> +Required properties for ISC:
>>> +- compatible
>>> +	Must be "atmel,sama5d2-isc"
>>> +- reg
>>> +	Physical base address and length of the registers set for the device;
>>> +- interrupts
>>> +	Should contain IRQ line for the ISI;
>>> +- clocks
>>> +	List of clock specifiers, corresponding to entries in
>>> +	the clock-names property;
>>> +	Please refer to clock-bindings.txt.
>>> +- clock-names
>>> +	Required elements: "hclock", "ispck".
>>> +- pinctrl-names, pinctrl-0
>>> +	Please refer to pinctrl-bindings.txt.
>>> +- isc-ispck
>>> +	The clock for the ISC digital pipeline.
>>> +	- compatible
>>> +		Must be "atmel,sama5d2-isc-ispck".
>>> +	- clock-cells
>>> +		From common clock binding; should be set to 0.
>>> +	- clocks
>>> +		The clock source phandles.
>>> +- isc-mck
>>> +	The clock for the image sensor.
>>> +	- compatible
>>> +		Must be "atmel,sama5d2-isc-mck".
>>> +	- clock-cells
>>> +		From common clock binding; should be set to 0.
>>> +	- clocks
>>> +		The clock source phandles.
>>> +
>>> +ISC supports a single port node with parallel bus. It should contain one
>>> +'port' child node with child 'endpoint' node. Please refer to the bindings
>>> +defined in Documentation/devicetree/bindings/media/video-interfaces.txt.
>>> +
>>> +Example:
>>> +isc: isc@f0008000 {
>>> +	compatible = "atmel,sama5d2-isc";
>>> +	reg = <0xf0008000 0x4000>;
>>> +	interrupts = <46 IRQ_TYPE_LEVEL_HIGH 5>;
>>> +	clocks = <&isc_clk>, <&isc_ispck>;
>>> +	clock-names = "hclock", "ispck";
>>> +
>>> +	port {
>>> +		#address-cells = <1>;
>>> +		#size-cells = <0>;
>>> +
>>> +		isc_0: endpoint {
>>> +			remote-endpoint = <&ov7740_0>;
>>> +			hsync-active = <1>;
>>> +			vsync-active = <0>;
>>> +			pclk-sample = <1>;
>>> +		};
>>> +	};
>>> +
>>> +	isc_ispck: isc-ispck@0 {
>>
>> Drop the unit-address. You should only have one if you have a reg
>> property.
>>
>>> +		compatible = "atmel,sama5d2-isc-ispck";
>>> +		#clock-cells = <0>;
>>> +		clocks = <&isc_clk>, <&iscck>;
>>> +	};
>>> +
>>> +	isc_mck: isc-mck@1 {
>>
>> ditto.
>>
>> I still think these should be implied by atmel,sama5d2-isc and not in
>> DT. The fact that you don't have any registers for them pretty much
>> indicates that. It is also strange that isc-ispck is used by isc. If
>> that is the only user, there is certainly no need to put it in DT.
>
> I had a look at the block diagram, and it seems you are partially right.
> The only clock that is really exported by the ISC is isc_mck (isc_pck is
> not).
> So I'd suggest dropping these clk sub-nodes, putting the #clock-cells,
> and clock-names properties in the isc node, and then referencing the
> isc node in you i2c device.
>
> isc: isc@f0008000 {
> 	compatible = "atmel,sama5d2-isc";
> 	reg = <0xf0008000 0x4000>;
> 	interrupts = <46 IRQ_TYPE_LEVEL_HIGH 5>;
> 	clocks = <&isc_clk>, <&isc_ispck>;
> 	clock-names = "hclock", "ispck";
> 	#clock-cells = <0>;
> 	clock-output-names = "isc-mck";
> };
>
> i2c1: i2c@fc028000 {
> 	/* ... */
> 	ov7740: camera@21 {
> 		/* ... */
> 		clocks = <&isc>;
> 		clock-names = "xvclk";
> 	}
> };
>
> If I'm wrong and the ISC IP is really exposing several clks, you just
> have to change #clock-cells to 1, and use clocks = <&isc X>; in the i2c
> device node.
>
> Rob, Songjun, would you agree on this representation?
>
Agree, I think it's a good solution.
Thank you for your comments.
>>
>>
>>> +		compatible = "atmel,sama5d2-isc-mck";
>>> +		#clock-cells = <0>;
>>> +		clocks = <&isc_clk>, <&iscck>, <&isc_gclk>;
>>> +	};
>>> +};
>>> +
>>> +i2c1: i2c@fc028000 {
>>> +	ov7740: camera@21 {
>>> +	compatible = "ovti,ov7740";
>>> +	reg = <0x21>;
>>> +
>>> +	clocks = <&isc_mck>;
>>> +	clock-names = "xvclk";
>>> +	assigned-clocks = <&isc_mck>;
>>> +	assigned-clock-rates = <24000000>;
>>> +
>>> +	port {
>>> +		ov7740_0: endpoint {
>>> +			remote-endpoint = <&isc_0>;
>>> +		};
>>> +	};
>>> +};
>>> --
>>> 2.7.4
>>>
>>
>> _______________________________________________
>> linux-arm-kernel mailing list
>> linux-arm-kernel@lists.infradead.org
>> http://lists.infradead.org/mailman/listinfo/linux-arm-kernel
>
>
>

^ permalink raw reply	[flat|nested] 7+ messages in thread

end of thread, other threads:[~2016-06-06  6:44 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2016-05-31  6:58 [PATCH v3 0/2] [media] atmel-isc: add driver for Atmel ISC Songjun Wu
2016-05-31  6:58 ` [PATCH v3 2/2] [media] atmel-isc: DT binding for Image Sensor Controller driver Songjun Wu
2016-06-02 23:16   ` Rob Herring
2016-06-03 11:10     ` Boris Brezillon
2016-06-06  6:44       ` Wu, Songjun
2016-06-06  6:42     ` Wu, Songjun
     [not found] ` <1464677903-28412-1-git-send-email-songjun.wu-AIFe0yeh4nAAvxtiuMwx3w@public.gmane.org>
2016-05-31  7:17   ` [PATCH v3 0/2] [media] atmel-isc: add driver for Atmel ISC Geert Uytterhoeven

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).