[PATCH] [v3] i.MX27: Fix emma-prp clocks in mx2_camera.c

2012-07-06 Thread Javier Martin
This driver wasn't converted to the new clock changes
(clk_prepare_enable/clk_disable_unprepare). Also naming
of emma-prp related clocks for the i.MX27 was not correct.
---
Enable clocks only for i.MX27.

---
 arch/arm/mach-imx/clk-imx27.c|8 +++--
 drivers/media/video/mx2_camera.c |   67 ++
 2 files changed, 44 insertions(+), 31 deletions(-)

diff --git a/arch/arm/mach-imx/clk-imx27.c b/arch/arm/mach-imx/clk-imx27.c
index 295cbd7..373c8fd 100644
--- a/arch/arm/mach-imx/clk-imx27.c
+++ b/arch/arm/mach-imx/clk-imx27.c
@@ -223,7 +223,7 @@ int __init mx27_clocks_init(unsigned long fref)
clk_register_clkdev(clk[per3_gate], "per", "imx-fb.0");
clk_register_clkdev(clk[lcdc_ipg_gate], "ipg", "imx-fb.0");
clk_register_clkdev(clk[lcdc_ahb_gate], "ahb", "imx-fb.0");
-   clk_register_clkdev(clk[csi_ahb_gate], NULL, "mx2-camera.0");
+   clk_register_clkdev(clk[csi_ahb_gate], "ahb", "mx2-camera.0");
clk_register_clkdev(clk[usb_div], "per", "fsl-usb2-udc");
clk_register_clkdev(clk[usb_ipg_gate], "ipg", "fsl-usb2-udc");
clk_register_clkdev(clk[usb_ahb_gate], "ahb", "fsl-usb2-udc");
@@ -250,8 +250,10 @@ int __init mx27_clocks_init(unsigned long fref)
clk_register_clkdev(clk[i2c2_ipg_gate], NULL, "imx-i2c.1");
clk_register_clkdev(clk[owire_ipg_gate], NULL, "mxc_w1.0");
clk_register_clkdev(clk[kpp_ipg_gate], NULL, "imx-keypad");
-   clk_register_clkdev(clk[emma_ahb_gate], "ahb", "imx-emma");
-   clk_register_clkdev(clk[emma_ipg_gate], "ipg", "imx-emma");
+   clk_register_clkdev(clk[emma_ahb_gate], "emma-ahb", "mx2-camera.0");
+   clk_register_clkdev(clk[emma_ipg_gate], "emma-ipg", "mx2-camera.0");
+   clk_register_clkdev(clk[emma_ahb_gate], "ahb", "m2m-emmaprp.0");
+   clk_register_clkdev(clk[emma_ipg_gate], "ipg", "m2m-emmaprp.0");
clk_register_clkdev(clk[iim_ipg_gate], "iim", NULL);
clk_register_clkdev(clk[gpio_ipg_gate], "gpio", NULL);
clk_register_clkdev(clk[brom_ahb_gate], "brom", NULL);
diff --git a/drivers/media/video/mx2_camera.c b/drivers/media/video/mx2_camera.c
index 41f9a25..11a9353 100644
--- a/drivers/media/video/mx2_camera.c
+++ b/drivers/media/video/mx2_camera.c
@@ -270,7 +270,7 @@ struct mx2_camera_dev {
struct device   *dev;
struct soc_camera_host  soc_host;
struct soc_camera_device *icd;
-   struct clk  *clk_csi, *clk_emma;
+   struct clk  *clk_csi, *clk_emma_ahb, *clk_emma_ipg;
 
unsigned intirq_csi, irq_emma;
void __iomem*base_csi, *base_emma;
@@ -389,7 +389,8 @@ static void mx2_camera_deactivate(struct mx2_camera_dev 
*pcdev)
 {
unsigned long flags;
 
-   clk_disable(pcdev->clk_csi);
+   if (cpu_is_mx27())
+   clk_disable_unprepare(pcdev->clk_csi);
writel(0, pcdev->base_csi + CSICR1);
if (cpu_is_mx27()) {
writel(0, pcdev->base_emma + PRP_CNTL);
@@ -417,9 +418,11 @@ static int mx2_camera_add_device(struct soc_camera_device 
*icd)
if (pcdev->icd)
return -EBUSY;
 
-   ret = clk_enable(pcdev->clk_csi);
-   if (ret < 0)
-   return ret;
+   if (cpu_is_mx27()) {
+   ret = clk_prepare_enable(pcdev->clk_csi);
+   if (ret < 0)
+   return ret;
+   }
 
csicr1 = CSICR1_MCLKEN;
 
@@ -1616,23 +1619,12 @@ static int __devinit mx27_camera_emma_init(struct 
mx2_camera_dev *pcdev)
goto exit_iounmap;
}
 
-   pcdev->clk_emma = clk_get(NULL, "emma");
-   if (IS_ERR(pcdev->clk_emma)) {
-   err = PTR_ERR(pcdev->clk_emma);
-   goto exit_free_irq;
-   }
-
-   clk_enable(pcdev->clk_emma);
-
err = mx27_camera_emma_prp_reset(pcdev);
if (err)
-   goto exit_clk_emma_put;
+   goto exit_free_irq;
 
return err;
 
-exit_clk_emma_put:
-   clk_disable(pcdev->clk_emma);
-   clk_put(pcdev->clk_emma);
 exit_free_irq:
free_irq(pcdev->irq_emma, pcdev);
 exit_iounmap:
@@ -1655,6 +1647,7 @@ static int __devinit mx2_camera_probe(struct 
platform_device *pdev)
 
res_csi = platform_get_resource(pdev, IORESOURCE_MEM, 0);
irq_csi = platform_get_irq(pdev, 0);
+
if (res_csi == NULL || irq_csi < 0) {
dev_err(&pdev->dev, "Missing platform resources data\n");
err = -ENODEV;
@@ -1668,11 +1661,26 @@ static int __devinit mx2_camera_probe(struct 
platform_device *pdev)
goto exit;
}
 
-   pcdev->clk_csi = clk_get(&pdev->dev, NULL);
-   if (IS_ERR(pcdev->clk_csi)) {
-   dev_err(&pdev->dev, "Could not get csi clock\n");
-   err = PTR_ERR(pcdev->clk_csi);
-   goto exit_kfree;
+   if (cpu_is_mx27()) {
+   pcdev->clk_csi = devm_clk_get(&pdev->dev, "ahb");
+   

Re: [PATCH] [v3] i.MX27: Fix emma-prp clocks in mx2_camera.c

2012-07-09 Thread Sascha Hauer
On Fri, Jul 06, 2012 at 12:56:02PM +0200, Javier Martin wrote:
> This driver wasn't converted to the new clock changes
> (clk_prepare_enable/clk_disable_unprepare). Also naming
> of emma-prp related clocks for the i.MX27 was not correct.
> ---
> Enable clocks only for i.MX27.
> 

Indeed,

>  
> - pcdev->clk_csi = clk_get(&pdev->dev, NULL);
> - if (IS_ERR(pcdev->clk_csi)) {
> - dev_err(&pdev->dev, "Could not get csi clock\n");
> - err = PTR_ERR(pcdev->clk_csi);
> - goto exit_kfree;
> + if (cpu_is_mx27()) {
> + pcdev->clk_csi = devm_clk_get(&pdev->dev, "ahb");
> + if (IS_ERR(pcdev->clk_csi)) {
> + dev_err(&pdev->dev, "Could not get csi clock\n");
> + err = PTR_ERR(pcdev->clk_csi);
> + goto exit_kfree;
> + }

but why? Now the i.MX25 won't get a clock anymore.

Sascha

-- 
Pengutronix e.K.   | |
Industrial Linux Solutions | http://www.pengutronix.de/  |
Peiner Str. 6-8, 31137 Hildesheim, Germany | Phone: +49-5121-206917-0|
Amtsgericht Hildesheim, HRA 2686   | Fax:   +49-5121-206917- |
--
To unsubscribe from this list: send the line "unsubscribe linux-media" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH] [v3] i.MX27: Fix emma-prp clocks in mx2_camera.c

2012-07-09 Thread javier Martin
On 9 July 2012 09:28, Sascha Hauer  wrote:
> On Fri, Jul 06, 2012 at 12:56:02PM +0200, Javier Martin wrote:
>> This driver wasn't converted to the new clock changes
>> (clk_prepare_enable/clk_disable_unprepare). Also naming
>> of emma-prp related clocks for the i.MX27 was not correct.
>> ---
>> Enable clocks only for i.MX27.
>>
>
> Indeed,
>
>>
>> - pcdev->clk_csi = clk_get(&pdev->dev, NULL);
>> - if (IS_ERR(pcdev->clk_csi)) {
>> - dev_err(&pdev->dev, "Could not get csi clock\n");
>> - err = PTR_ERR(pcdev->clk_csi);
>> - goto exit_kfree;
>> + if (cpu_is_mx27()) {
>> + pcdev->clk_csi = devm_clk_get(&pdev->dev, "ahb");
>> + if (IS_ERR(pcdev->clk_csi)) {
>> + dev_err(&pdev->dev, "Could not get csi clock\n");
>> + err = PTR_ERR(pcdev->clk_csi);
>> + goto exit_kfree;
>> + }
>
> but why? Now the i.MX25 won't get a clock anymore.

What are the clocks needed by i.MX25? csi only?

By the way, is anybody using this driver with i.MX25?

-- 
Javier Martin
Vista Silicon S.L.
CDTUC - FASE C - Oficina S-345
Avda de los Castros s/n
39005- Santander. Cantabria. Spain
+34 942 25 32 60
www.vista-silicon.com
--
To unsubscribe from this list: send the line "unsubscribe linux-media" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH] [v3] i.MX27: Fix emma-prp clocks in mx2_camera.c

2012-07-09 Thread Sascha Hauer
On Mon, Jul 09, 2012 at 09:37:25AM +0200, javier Martin wrote:
> On 9 July 2012 09:28, Sascha Hauer  wrote:
> > On Fri, Jul 06, 2012 at 12:56:02PM +0200, Javier Martin wrote:
> >> This driver wasn't converted to the new clock changes
> >> (clk_prepare_enable/clk_disable_unprepare). Also naming
> >> of emma-prp related clocks for the i.MX27 was not correct.
> >> ---
> >> Enable clocks only for i.MX27.
> >>
> >
> > Indeed,
> >
> >>
> >> - pcdev->clk_csi = clk_get(&pdev->dev, NULL);
> >> - if (IS_ERR(pcdev->clk_csi)) {
> >> - dev_err(&pdev->dev, "Could not get csi clock\n");
> >> - err = PTR_ERR(pcdev->clk_csi);
> >> - goto exit_kfree;
> >> + if (cpu_is_mx27()) {
> >> + pcdev->clk_csi = devm_clk_get(&pdev->dev, "ahb");
> >> + if (IS_ERR(pcdev->clk_csi)) {
> >> + dev_err(&pdev->dev, "Could not get csi clock\n");
> >> + err = PTR_ERR(pcdev->clk_csi);
> >> + goto exit_kfree;
> >> + }
> >
> > but why? Now the i.MX25 won't get a clock anymore.
> 
> What are the clocks needed by i.MX25? csi only?
> 
> By the way, is anybody using this driver with i.MX25?

It seems Baruch (added to Cc) has used it on an i.MX25.

Sascha


-- 
Pengutronix e.K.   | |
Industrial Linux Solutions | http://www.pengutronix.de/  |
Peiner Str. 6-8, 31137 Hildesheim, Germany | Phone: +49-5121-206917-0|
Amtsgericht Hildesheim, HRA 2686   | Fax:   +49-5121-206917- |
--
To unsubscribe from this list: send the line "unsubscribe linux-media" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH] [v3] i.MX27: Fix emma-prp clocks in mx2_camera.c

2012-07-09 Thread javier Martin
On 9 July 2012 09:43, Sascha Hauer  wrote:
> On Mon, Jul 09, 2012 at 09:37:25AM +0200, javier Martin wrote:
>> On 9 July 2012 09:28, Sascha Hauer  wrote:
>> > On Fri, Jul 06, 2012 at 12:56:02PM +0200, Javier Martin wrote:
>> >> This driver wasn't converted to the new clock changes
>> >> (clk_prepare_enable/clk_disable_unprepare). Also naming
>> >> of emma-prp related clocks for the i.MX27 was not correct.
>> >> ---
>> >> Enable clocks only for i.MX27.
>> >>
>> >
>> > Indeed,
>> >
>> >>
>> >> - pcdev->clk_csi = clk_get(&pdev->dev, NULL);
>> >> - if (IS_ERR(pcdev->clk_csi)) {
>> >> - dev_err(&pdev->dev, "Could not get csi clock\n");
>> >> - err = PTR_ERR(pcdev->clk_csi);
>> >> - goto exit_kfree;
>> >> + if (cpu_is_mx27()) {
>> >> + pcdev->clk_csi = devm_clk_get(&pdev->dev, "ahb");
>> >> + if (IS_ERR(pcdev->clk_csi)) {
>> >> + dev_err(&pdev->dev, "Could not get csi clock\n");
>> >> + err = PTR_ERR(pcdev->clk_csi);
>> >> + goto exit_kfree;
>> >> + }
>> >
>> > but why? Now the i.MX25 won't get a clock anymore.
>>
>> What are the clocks needed by i.MX25? csi only?
>>
>> By the way, is anybody using this driver with i.MX25?
>
> It seems Baruch (added to Cc) has used it on an i.MX25.

Baruch,
could you tell us what are the clocks needed by i.MX25?

Regards.
-- 
Javier Martin
Vista Silicon S.L.
CDTUC - FASE C - Oficina S-345
Avda de los Castros s/n
39005- Santander. Cantabria. Spain
+34 942 25 32 60
www.vista-silicon.com
--
To unsubscribe from this list: send the line "unsubscribe linux-media" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH] [v3] i.MX27: Fix emma-prp clocks in mx2_camera.c

2012-07-09 Thread Baruch Siach
Hi Javier,

On Mon, Jul 09, 2012 at 09:46:03AM +0200, javier Martin wrote:
> On 9 July 2012 09:43, Sascha Hauer  wrote:
> > On Mon, Jul 09, 2012 at 09:37:25AM +0200, javier Martin wrote:
> >> On 9 July 2012 09:28, Sascha Hauer  wrote:
> >> > On Fri, Jul 06, 2012 at 12:56:02PM +0200, Javier Martin wrote:
> >> >> This driver wasn't converted to the new clock changes
> >> >> (clk_prepare_enable/clk_disable_unprepare). Also naming
> >> >> of emma-prp related clocks for the i.MX27 was not correct.
> >> >> ---
> >> >> Enable clocks only for i.MX27.
> >> >
> >> > Indeed,
> >> >
> >> >> - pcdev->clk_csi = clk_get(&pdev->dev, NULL);
> >> >> - if (IS_ERR(pcdev->clk_csi)) {
> >> >> - dev_err(&pdev->dev, "Could not get csi clock\n");
> >> >> - err = PTR_ERR(pcdev->clk_csi);
> >> >> - goto exit_kfree;
> >> >> + if (cpu_is_mx27()) {
> >> >> + pcdev->clk_csi = devm_clk_get(&pdev->dev, "ahb");
> >> >> + if (IS_ERR(pcdev->clk_csi)) {
> >> >> + dev_err(&pdev->dev, "Could not get csi clock\n");
> >> >> + err = PTR_ERR(pcdev->clk_csi);
> >> >> + goto exit_kfree;
> >> >> + }
> >> >
> >> > but why? Now the i.MX25 won't get a clock anymore.
> >>
> >> What are the clocks needed by i.MX25? csi only?
> >>
> >> By the way, is anybody using this driver with i.MX25?
> >
> > It seems Baruch (added to Cc) has used it on an i.MX25.
> could you tell us what are the clocks needed by i.MX25?

According to the code the csi clock is sufficient for i.MX25. Unfortunately I 
don't have access to a running system anymore, so I can't test current code.

baruch

-- 
 http://baruch.siach.name/blog/  ~. .~   Tk Open Systems
=}ooO--U--Ooo{=
   - bar...@tkos.co.il - tel: +972.2.679.5364, http://www.tkos.co.il -
--
To unsubscribe from this list: send the line "unsubscribe linux-media" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH] [v3] i.MX27: Fix emma-prp clocks in mx2_camera.c

2012-07-09 Thread Sascha Hauer
On Mon, Jul 09, 2012 at 09:46:03AM +0200, javier Martin wrote:
> On 9 July 2012 09:43, Sascha Hauer  wrote:
> > On Mon, Jul 09, 2012 at 09:37:25AM +0200, javier Martin wrote:
> >> On 9 July 2012 09:28, Sascha Hauer  wrote:
> >> > On Fri, Jul 06, 2012 at 12:56:02PM +0200, Javier Martin wrote:
> >> >> This driver wasn't converted to the new clock changes
> >> >> (clk_prepare_enable/clk_disable_unprepare). Also naming
> >> >> of emma-prp related clocks for the i.MX27 was not correct.
> >> >> ---
> >> >> Enable clocks only for i.MX27.
> >> >>
> >> >
> >> > Indeed,
> >> >
> >> >>
> >> >> - pcdev->clk_csi = clk_get(&pdev->dev, NULL);
> >> >> - if (IS_ERR(pcdev->clk_csi)) {
> >> >> - dev_err(&pdev->dev, "Could not get csi clock\n");
> >> >> - err = PTR_ERR(pcdev->clk_csi);
> >> >> - goto exit_kfree;
> >> >> + if (cpu_is_mx27()) {
> >> >> + pcdev->clk_csi = devm_clk_get(&pdev->dev, "ahb");
> >> >> + if (IS_ERR(pcdev->clk_csi)) {
> >> >> + dev_err(&pdev->dev, "Could not get csi clock\n");
> >> >> + err = PTR_ERR(pcdev->clk_csi);
> >> >> + goto exit_kfree;
> >> >> + }
> >> >
> >> > but why? Now the i.MX25 won't get a clock anymore.
> >>
> >> What are the clocks needed by i.MX25? csi only?
> >>
> >> By the way, is anybody using this driver with i.MX25?
> >
> > It seems Baruch (added to Cc) has used it on an i.MX25.
> 
> Baruch,
> could you tell us what are the clocks needed by i.MX25?

I just had a look and the i.MX25 it needs three clocks: ipg, ahb and
peripheral clock. So this is broken anyway and should probably be fixed
seperately, that is:

- provide dummy clocks for the csi clocks on i.MX27
- clk_get ipg, ahb and peripheral clocks on all SoCs
- clk_get emma clocks on i.MX27 only

As said, this is a separate topic, so your original patch should be fine
for now.

Sascha


-- 
Pengutronix e.K.   | |
Industrial Linux Solutions | http://www.pengutronix.de/  |
Peiner Str. 6-8, 31137 Hildesheim, Germany | Phone: +49-5121-206917-0|
Amtsgericht Hildesheim, HRA 2686   | Fax:   +49-5121-206917- |
--
To unsubscribe from this list: send the line "unsubscribe linux-media" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH] [v3] i.MX27: Fix emma-prp clocks in mx2_camera.c

2012-07-09 Thread javier Martin
On 9 July 2012 10:07, Sascha Hauer  wrote:
> On Mon, Jul 09, 2012 at 09:46:03AM +0200, javier Martin wrote:
>> On 9 July 2012 09:43, Sascha Hauer  wrote:
>> > On Mon, Jul 09, 2012 at 09:37:25AM +0200, javier Martin wrote:
>> >> On 9 July 2012 09:28, Sascha Hauer  wrote:
>> >> > On Fri, Jul 06, 2012 at 12:56:02PM +0200, Javier Martin wrote:
>> >> >> This driver wasn't converted to the new clock changes
>> >> >> (clk_prepare_enable/clk_disable_unprepare). Also naming
>> >> >> of emma-prp related clocks for the i.MX27 was not correct.
>> >> >> ---
>> >> >> Enable clocks only for i.MX27.
>> >> >>
>> >> >
>> >> > Indeed,
>> >> >
>> >> >>
>> >> >> - pcdev->clk_csi = clk_get(&pdev->dev, NULL);
>> >> >> - if (IS_ERR(pcdev->clk_csi)) {
>> >> >> - dev_err(&pdev->dev, "Could not get csi clock\n");
>> >> >> - err = PTR_ERR(pcdev->clk_csi);
>> >> >> - goto exit_kfree;
>> >> >> + if (cpu_is_mx27()) {
>> >> >> + pcdev->clk_csi = devm_clk_get(&pdev->dev, "ahb");
>> >> >> + if (IS_ERR(pcdev->clk_csi)) {
>> >> >> + dev_err(&pdev->dev, "Could not get csi clock\n");
>> >> >> + err = PTR_ERR(pcdev->clk_csi);
>> >> >> + goto exit_kfree;
>> >> >> + }
>> >> >
>> >> > but why? Now the i.MX25 won't get a clock anymore.
>> >>
>> >> What are the clocks needed by i.MX25? csi only?
>> >>
>> >> By the way, is anybody using this driver with i.MX25?
>> >
>> > It seems Baruch (added to Cc) has used it on an i.MX25.
>>
>> Baruch,
>> could you tell us what are the clocks needed by i.MX25?
>
> I just had a look and the i.MX25 it needs three clocks: ipg, ahb and
> peripheral clock. So this is broken anyway and should probably be fixed
> seperately, that is:
>
> - provide dummy clocks for the csi clocks on i.MX27
> - clk_get ipg, ahb and peripheral clocks on all SoCs
> - clk_get emma clocks on i.MX27 only
>
> As said, this is a separate topic, so your original patch should be fine
> for now.

OK, thanks for your interest.

Regards.
-- 
Javier Martin
Vista Silicon S.L.
CDTUC - FASE C - Oficina S-345
Avda de los Castros s/n
39005- Santander. Cantabria. Spain
+34 942 25 32 60
www.vista-silicon.com
--
To unsubscribe from this list: send the line "unsubscribe linux-media" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH] [v3] i.MX27: Fix emma-prp clocks in mx2_camera.c

2012-07-20 Thread Guennadi Liakhovetski
Hi Javier

Thanks for the patch

On Mon, 9 Jul 2012, javier Martin wrote:

> On 9 July 2012 10:07, Sascha Hauer  wrote:
> > On Mon, Jul 09, 2012 at 09:46:03AM +0200, javier Martin wrote:
> >> On 9 July 2012 09:43, Sascha Hauer  wrote:
> >> > On Mon, Jul 09, 2012 at 09:37:25AM +0200, javier Martin wrote:
> >> >> On 9 July 2012 09:28, Sascha Hauer  wrote:
> >> >> > On Fri, Jul 06, 2012 at 12:56:02PM +0200, Javier Martin wrote:
> >> >> >> This driver wasn't converted to the new clock changes
> >> >> >> (clk_prepare_enable/clk_disable_unprepare). Also naming
> >> >> >> of emma-prp related clocks for the i.MX27 was not correct.
> >> >> >> ---
> >> >> >> Enable clocks only for i.MX27.
> >> >> >>
> >> >> >
> >> >> > Indeed,
> >> >> >
> >> >> >>
> >> >> >> - pcdev->clk_csi = clk_get(&pdev->dev, NULL);
> >> >> >> - if (IS_ERR(pcdev->clk_csi)) {
> >> >> >> - dev_err(&pdev->dev, "Could not get csi clock\n");
> >> >> >> - err = PTR_ERR(pcdev->clk_csi);
> >> >> >> - goto exit_kfree;
> >> >> >> + if (cpu_is_mx27()) {
> >> >> >> + pcdev->clk_csi = devm_clk_get(&pdev->dev, "ahb");
> >> >> >> + if (IS_ERR(pcdev->clk_csi)) {
> >> >> >> + dev_err(&pdev->dev, "Could not get csi 
> >> >> >> clock\n");
> >> >> >> + err = PTR_ERR(pcdev->clk_csi);
> >> >> >> + goto exit_kfree;
> >> >> >> + }
> >> >> >
> >> >> > but why? Now the i.MX25 won't get a clock anymore.
> >> >>
> >> >> What are the clocks needed by i.MX25? csi only?
> >> >>
> >> >> By the way, is anybody using this driver with i.MX25?
> >> >
> >> > It seems Baruch (added to Cc) has used it on an i.MX25.
> >>
> >> Baruch,
> >> could you tell us what are the clocks needed by i.MX25?
> >
> > I just had a look and the i.MX25 it needs three clocks: ipg, ahb and
> > peripheral clock. So this is broken anyway and should probably be fixed
> > seperately, that is:
> >
> > - provide dummy clocks for the csi clocks on i.MX27
> > - clk_get ipg, ahb and peripheral clocks on all SoCs
> > - clk_get emma clocks on i.MX27 only
> >
> > As said, this is a separate topic, so your original patch should be fine
> > for now.

Well, sorry, but I don't think I can share this.

1. it touches two areas - arch/ and drivers/ which isnÄt a good thing and 
   should be avoided wherever possible
2. it addresses several problems: (a) missing name for "ahb" camera clock, 
   (b) wrong device and connection names for emma clocks, (c) missing 
   _(un)prepare suffixes in clock API
3. it makes a possibly broken i.MX25 even more broken

IIUC, mx2-camera is broken on i.MX27 in current next because of wrong 
clock entries, right? So, we don't have to be bothered not to break 
bisection - it is already broken. Then we can clean up the problems 
separately under arch/ and drivers/.

So, would it be possible to split this into 3 parts:

(a) arch - fix clocks
(b) media - fix clocks on i.MX27 _without_ breaking it even further on 
i.MX25. If we think i.MX25 support is already broken, let's schedule 
its removal and remove properly, or add BROKEN to Kconfig, when built 
on i.MX25. In your patch this would mean just adding an "else" to your 
"if (cpu_is_mx27())" statement and moving the current clk_get() there
(c) add _(un)prepare.

Since these are fixes, I won't wait too long for these. If you don't 
resubmit them today, they'll go in after 3.6-rc1.

Thanks
Guennadi

> OK, thanks for your interest.
> 
> Regards.
> -- 
> Javier Martin
> Vista Silicon S.L.
> CDTUC - FASE C - Oficina S-345
> Avda de los Castros s/n
> 39005- Santander. Cantabria. Spain
> +34 942 25 32 60
> www.vista-silicon.com
> 

---
Guennadi Liakhovetski, Ph.D.
Freelance Open-Source Software Developer
http://www.open-technology.de/
--
To unsubscribe from this list: send the line "unsubscribe linux-media" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCH] [v3] i.MX27: Fix emma-prp clocks in mx2_camera.c

2012-07-20 Thread javier Martin
On 20 July 2012 13:19, Guennadi Liakhovetski  wrote:
> Hi Javier
>
> Thanks for the patch
>
> On Mon, 9 Jul 2012, javier Martin wrote:
>
>> On 9 July 2012 10:07, Sascha Hauer  wrote:
>> > On Mon, Jul 09, 2012 at 09:46:03AM +0200, javier Martin wrote:
>> >> On 9 July 2012 09:43, Sascha Hauer  wrote:
>> >> > On Mon, Jul 09, 2012 at 09:37:25AM +0200, javier Martin wrote:
>> >> >> On 9 July 2012 09:28, Sascha Hauer  wrote:
>> >> >> > On Fri, Jul 06, 2012 at 12:56:02PM +0200, Javier Martin wrote:
>> >> >> >> This driver wasn't converted to the new clock changes
>> >> >> >> (clk_prepare_enable/clk_disable_unprepare). Also naming
>> >> >> >> of emma-prp related clocks for the i.MX27 was not correct.
>> >> >> >> ---
>> >> >> >> Enable clocks only for i.MX27.
>> >> >> >>
>> >> >> >
>> >> >> > Indeed,
>> >> >> >
>> >> >> >>
>> >> >> >> - pcdev->clk_csi = clk_get(&pdev->dev, NULL);
>> >> >> >> - if (IS_ERR(pcdev->clk_csi)) {
>> >> >> >> - dev_err(&pdev->dev, "Could not get csi clock\n");
>> >> >> >> - err = PTR_ERR(pcdev->clk_csi);
>> >> >> >> - goto exit_kfree;
>> >> >> >> + if (cpu_is_mx27()) {
>> >> >> >> + pcdev->clk_csi = devm_clk_get(&pdev->dev, "ahb");
>> >> >> >> + if (IS_ERR(pcdev->clk_csi)) {
>> >> >> >> + dev_err(&pdev->dev, "Could not get csi 
>> >> >> >> clock\n");
>> >> >> >> + err = PTR_ERR(pcdev->clk_csi);
>> >> >> >> + goto exit_kfree;
>> >> >> >> + }
>> >> >> >
>> >> >> > but why? Now the i.MX25 won't get a clock anymore.
>> >> >>
>> >> >> What are the clocks needed by i.MX25? csi only?
>> >> >>
>> >> >> By the way, is anybody using this driver with i.MX25?
>> >> >
>> >> > It seems Baruch (added to Cc) has used it on an i.MX25.
>> >>
>> >> Baruch,
>> >> could you tell us what are the clocks needed by i.MX25?
>> >
>> > I just had a look and the i.MX25 it needs three clocks: ipg, ahb and
>> > peripheral clock. So this is broken anyway and should probably be fixed
>> > seperately, that is:
>> >
>> > - provide dummy clocks for the csi clocks on i.MX27
>> > - clk_get ipg, ahb and peripheral clocks on all SoCs
>> > - clk_get emma clocks on i.MX27 only
>> >
>> > As said, this is a separate topic, so your original patch should be fine
>> > for now.
>
> Well, sorry, but I don't think I can share this.
>
> 1. it touches two areas - arch/ and drivers/ which isnÄt a good thing and
>should be avoided wherever possible
> 2. it addresses several problems: (a) missing name for "ahb" camera clock,
>(b) wrong device and connection names for emma clocks, (c) missing
>_(un)prepare suffixes in clock API
> 3. it makes a possibly broken i.MX25 even more broken
>
> IIUC, mx2-camera is broken on i.MX27 in current next because of wrong
> clock entries, right? So, we don't have to be bothered not to break
> bisection - it is already broken. Then we can clean up the problems
> separately under arch/ and drivers/.
>
> So, would it be possible to split this into 3 parts:
>
> (a) arch - fix clocks
> (b) media - fix clocks on i.MX27 _without_ breaking it even further on
> i.MX25. If we think i.MX25 support is already broken, let's schedule
> its removal and remove properly, or add BROKEN to Kconfig, when built
> on i.MX25. In your patch this would mean just adding an "else" to your
> "if (cpu_is_mx27())" statement and moving the current clk_get() there
> (c) add _(un)prepare.
>
> Since these are fixes, I won't wait too long for these. If you don't
> resubmit them today, they'll go in after 3.6-rc1.
>
> Thanks
> Guennadi
>
>> OK, thanks for your interest.
>>
>> Regards.
>> --
>> Javier Martin
>> Vista Silicon S.L.
>> CDTUC - FASE C - Oficina S-345
>> Avda de los Castros s/n
>> 39005- Santander. Cantabria. Spain
>> +34 942 25 32 60
>> www.vista-silicon.com
>>
>

Hi Guennadi,
thanks for your review.

I could agree with some of your reasons for not accepting this patch.
Specially (1) and (2).
As regards of reason (3), i.MX25 has been broken for months and I
refuse that a broken chip that no known board in the mainline uses is
constantly slowing the development process.

Furthermore, I sent v3 of this patch 11 days ago. I know you are a
busy developer but, honestly, it doesn't seem fair that, having sent
the patch with plenty of time I am now given only this little time to
fix it. I'm out of the office right now and I won't come back until
monday. Couldn't you either make an exception and accept the path or
give me until monday in the morning to send the new version?

Alternatively, Sascha, Fabio or any other i.MX27 user could send it
too if they have the time.

Otherwise, as you stated it'll have to wait to 3.6-rc1. So 3.5 will be
broken for i.MX27.

Regards.

-- 
Javier Martin
Vista Silicon S.L.
CDTUC - FASE C - Oficina S-345
Avda de los Castros s/n
39005- Santander. Cantabria. Spain
+34 942 25 32 60
www.vista-silicon.com
--
To unsubscribe from this list: send the 

Re: [PATCH] [v3] i.MX27: Fix emma-prp clocks in mx2_camera.c

2012-07-20 Thread Guennadi Liakhovetski
On Fri, 20 Jul 2012, javier Martin wrote:

> On 20 July 2012 13:19, Guennadi Liakhovetski  wrote:
> > Hi Javier
> >
> > Thanks for the patch
> >
> > On Mon, 9 Jul 2012, javier Martin wrote:
> >
> >> On 9 July 2012 10:07, Sascha Hauer  wrote:
> >> > On Mon, Jul 09, 2012 at 09:46:03AM +0200, javier Martin wrote:
> >> >> On 9 July 2012 09:43, Sascha Hauer  wrote:
> >> >> > On Mon, Jul 09, 2012 at 09:37:25AM +0200, javier Martin wrote:
> >> >> >> On 9 July 2012 09:28, Sascha Hauer  wrote:
> >> >> >> > On Fri, Jul 06, 2012 at 12:56:02PM +0200, Javier Martin wrote:
> >> >> >> >> This driver wasn't converted to the new clock changes
> >> >> >> >> (clk_prepare_enable/clk_disable_unprepare). Also naming
> >> >> >> >> of emma-prp related clocks for the i.MX27 was not correct.
> >> >> >> >> ---
> >> >> >> >> Enable clocks only for i.MX27.
> >> >> >> >>
> >> >> >> >
> >> >> >> > Indeed,
> >> >> >> >
> >> >> >> >>
> >> >> >> >> - pcdev->clk_csi = clk_get(&pdev->dev, NULL);
> >> >> >> >> - if (IS_ERR(pcdev->clk_csi)) {
> >> >> >> >> - dev_err(&pdev->dev, "Could not get csi clock\n");
> >> >> >> >> - err = PTR_ERR(pcdev->clk_csi);
> >> >> >> >> - goto exit_kfree;
> >> >> >> >> + if (cpu_is_mx27()) {
> >> >> >> >> + pcdev->clk_csi = devm_clk_get(&pdev->dev, "ahb");
> >> >> >> >> + if (IS_ERR(pcdev->clk_csi)) {
> >> >> >> >> + dev_err(&pdev->dev, "Could not get csi 
> >> >> >> >> clock\n");
> >> >> >> >> + err = PTR_ERR(pcdev->clk_csi);
> >> >> >> >> + goto exit_kfree;
> >> >> >> >> + }
> >> >> >> >
> >> >> >> > but why? Now the i.MX25 won't get a clock anymore.
> >> >> >>
> >> >> >> What are the clocks needed by i.MX25? csi only?
> >> >> >>
> >> >> >> By the way, is anybody using this driver with i.MX25?
> >> >> >
> >> >> > It seems Baruch (added to Cc) has used it on an i.MX25.
> >> >>
> >> >> Baruch,
> >> >> could you tell us what are the clocks needed by i.MX25?
> >> >
> >> > I just had a look and the i.MX25 it needs three clocks: ipg, ahb and
> >> > peripheral clock. So this is broken anyway and should probably be fixed
> >> > seperately, that is:
> >> >
> >> > - provide dummy clocks for the csi clocks on i.MX27
> >> > - clk_get ipg, ahb and peripheral clocks on all SoCs
> >> > - clk_get emma clocks on i.MX27 only
> >> >
> >> > As said, this is a separate topic, so your original patch should be fine
> >> > for now.
> >
> > Well, sorry, but I don't think I can share this.
> >
> > 1. it touches two areas - arch/ and drivers/ which isnÄt a good thing and
> >should be avoided wherever possible
> > 2. it addresses several problems: (a) missing name for "ahb" camera clock,
> >(b) wrong device and connection names for emma clocks, (c) missing
> >_(un)prepare suffixes in clock API
> > 3. it makes a possibly broken i.MX25 even more broken
> >
> > IIUC, mx2-camera is broken on i.MX27 in current next because of wrong
> > clock entries, right? So, we don't have to be bothered not to break
> > bisection - it is already broken. Then we can clean up the problems
> > separately under arch/ and drivers/.
> >
> > So, would it be possible to split this into 3 parts:
> >
> > (a) arch - fix clocks
> > (b) media - fix clocks on i.MX27 _without_ breaking it even further on
> > i.MX25. If we think i.MX25 support is already broken, let's schedule
> > its removal and remove properly, or add BROKEN to Kconfig, when built
> > on i.MX25. In your patch this would mean just adding an "else" to your
> > "if (cpu_is_mx27())" statement and moving the current clk_get() there
> > (c) add _(un)prepare.
> >
> > Since these are fixes, I won't wait too long for these. If you don't
> > resubmit them today, they'll go in after 3.6-rc1.
> >
> > Thanks
> > Guennadi
> >
> >> OK, thanks for your interest.
> >>
> >> Regards.
> >> --
> >> Javier Martin
> >> Vista Silicon S.L.
> >> CDTUC - FASE C - Oficina S-345
> >> Avda de los Castros s/n
> >> 39005- Santander. Cantabria. Spain
> >> +34 942 25 32 60
> >> www.vista-silicon.com
> >>
> >
> 
> Hi Guennadi,
> thanks for your review.
> 
> I could agree with some of your reasons for not accepting this patch.
> Specially (1) and (2).
> As regards of reason (3), i.MX25 has been broken for months and I
> refuse that a broken chip that no known board in the mainline uses is
> constantly slowing the development process.
> 
> Furthermore, I sent v3 of this patch 11 days ago. I know you are a
> busy developer but, honestly, it doesn't seem fair that, having sent
> the patch with plenty of time I am now given only this little time to
> fix it. I'm out of the office right now and I won't come back until
> monday. Couldn't you either make an exception and accept the path or
> give me until monday in the morning to send the new version?
> 
> Alternatively, Sascha, Fabio or any other i.MX27 user could send it
> too if they have the time.
> 
> Otherwise, as you sta

Re: [PATCH] [v3] i.MX27: Fix emma-prp clocks in mx2_camera.c

2012-07-23 Thread javier Martin
On 20 July 2012 15:43, Guennadi Liakhovetski  wrote:
> On Fri, 20 Jul 2012, javier Martin wrote:
>
>> On 20 July 2012 13:19, Guennadi Liakhovetski  wrote:
>> > Hi Javier
>> >
>> > Thanks for the patch
>> >
>> > On Mon, 9 Jul 2012, javier Martin wrote:
>> >
>> >> On 9 July 2012 10:07, Sascha Hauer  wrote:
>> >> > On Mon, Jul 09, 2012 at 09:46:03AM +0200, javier Martin wrote:
>> >> >> On 9 July 2012 09:43, Sascha Hauer  wrote:
>> >> >> > On Mon, Jul 09, 2012 at 09:37:25AM +0200, javier Martin wrote:
>> >> >> >> On 9 July 2012 09:28, Sascha Hauer  wrote:
>> >> >> >> > On Fri, Jul 06, 2012 at 12:56:02PM +0200, Javier Martin wrote:
>> >> >> >> >> This driver wasn't converted to the new clock changes
>> >> >> >> >> (clk_prepare_enable/clk_disable_unprepare). Also naming
>> >> >> >> >> of emma-prp related clocks for the i.MX27 was not correct.
>> >> >> >> >> ---
>> >> >> >> >> Enable clocks only for i.MX27.
>> >> >> >> >>
>> >> >> >> >
>> >> >> >> > Indeed,
>> >> >> >> >
>> >> >> >> >>
>> >> >> >> >> - pcdev->clk_csi = clk_get(&pdev->dev, NULL);
>> >> >> >> >> - if (IS_ERR(pcdev->clk_csi)) {
>> >> >> >> >> - dev_err(&pdev->dev, "Could not get csi clock\n");
>> >> >> >> >> - err = PTR_ERR(pcdev->clk_csi);
>> >> >> >> >> - goto exit_kfree;
>> >> >> >> >> + if (cpu_is_mx27()) {
>> >> >> >> >> + pcdev->clk_csi = devm_clk_get(&pdev->dev, "ahb");
>> >> >> >> >> + if (IS_ERR(pcdev->clk_csi)) {
>> >> >> >> >> + dev_err(&pdev->dev, "Could not get csi 
>> >> >> >> >> clock\n");
>> >> >> >> >> + err = PTR_ERR(pcdev->clk_csi);
>> >> >> >> >> + goto exit_kfree;
>> >> >> >> >> + }
>> >> >> >> >
>> >> >> >> > but why? Now the i.MX25 won't get a clock anymore.
>> >> >> >>
>> >> >> >> What are the clocks needed by i.MX25? csi only?
>> >> >> >>
>> >> >> >> By the way, is anybody using this driver with i.MX25?
>> >> >> >
>> >> >> > It seems Baruch (added to Cc) has used it on an i.MX25.
>> >> >>
>> >> >> Baruch,
>> >> >> could you tell us what are the clocks needed by i.MX25?
>> >> >
>> >> > I just had a look and the i.MX25 it needs three clocks: ipg, ahb and
>> >> > peripheral clock. So this is broken anyway and should probably be fixed
>> >> > seperately, that is:
>> >> >
>> >> > - provide dummy clocks for the csi clocks on i.MX27
>> >> > - clk_get ipg, ahb and peripheral clocks on all SoCs
>> >> > - clk_get emma clocks on i.MX27 only
>> >> >
>> >> > As said, this is a separate topic, so your original patch should be fine
>> >> > for now.
>> >
>> > Well, sorry, but I don't think I can share this.
>> >
>> > 1. it touches two areas - arch/ and drivers/ which isnÄt a good thing and
>> >should be avoided wherever possible
>> > 2. it addresses several problems: (a) missing name for "ahb" camera clock,
>> >(b) wrong device and connection names for emma clocks, (c) missing
>> >_(un)prepare suffixes in clock API
>> > 3. it makes a possibly broken i.MX25 even more broken
>> >
>> > IIUC, mx2-camera is broken on i.MX27 in current next because of wrong
>> > clock entries, right? So, we don't have to be bothered not to break
>> > bisection - it is already broken. Then we can clean up the problems
>> > separately under arch/ and drivers/.
>> >
>> > So, would it be possible to split this into 3 parts:
>> >
>> > (a) arch - fix clocks
>> > (b) media - fix clocks on i.MX27 _without_ breaking it even further on
>> > i.MX25. If we think i.MX25 support is already broken, let's schedule
>> > its removal and remove properly, or add BROKEN to Kconfig, when built
>> > on i.MX25. In your patch this would mean just adding an "else" to your
>> > "if (cpu_is_mx27())" statement and moving the current clk_get() there
>> > (c) add _(un)prepare.
>> >
>> > Since these are fixes, I won't wait too long for these. If you don't
>> > resubmit them today, they'll go in after 3.6-rc1.
>> >
>> > Thanks
>> > Guennadi
>> >
>> >> OK, thanks for your interest.
>> >>
>> >> Regards.
>> >> --
>> >> Javier Martin
>> >> Vista Silicon S.L.
>> >> CDTUC - FASE C - Oficina S-345
>> >> Avda de los Castros s/n
>> >> 39005- Santander. Cantabria. Spain
>> >> +34 942 25 32 60
>> >> www.vista-silicon.com
>> >>
>> >
>>
>> Hi Guennadi,
>> thanks for your review.
>>
>> I could agree with some of your reasons for not accepting this patch.
>> Specially (1) and (2).
>> As regards of reason (3), i.MX25 has been broken for months and I
>> refuse that a broken chip that no known board in the mainline uses is
>> constantly slowing the development process.
>>
>> Furthermore, I sent v3 of this patch 11 days ago. I know you are a
>> busy developer but, honestly, it doesn't seem fair that, having sent
>> the patch with plenty of time I am now given only this little time to
>> fix it. I'm out of the office right now and I won't come back until
>> monday. Couldn't you either make an exception and accept the path or
>> give me until mond