Re: [PATCH v3 6/9] dmaengine: ti-dma-crossbar: Fix of_device_id data parameter usage

2016-09-27 Thread Vinod Koul
On Wed, Sep 21, 2016 at 03:41:32PM +0300, Peter Ujfalusi wrote:
> @@ -395,7 +403,7 @@ static int ti_dra7_xbar_probe(struct platform_device 
> *pdev)
>  
>   xbar->dmarouter.dev = >dev;
>   xbar->dmarouter.route_free = ti_dra7_xbar_free;
> - xbar->dma_offset = (u32)match->data;
> + xbar->dma_offset = *(u32*)match->data;
 
we need space between u32 and *

>   mutex_init(>mutex);
>   platform_set_drvdata(pdev, xbar);
> @@ -428,7 +436,7 @@ static int ti_dma_xbar_probe(struct platform_device *pdev)
>   if (unlikely(!match))
>   return -EINVAL;
>  
> - switch ((u32)match->data) {
> + switch (*(u32*)match->data) {

here too please

-- 
~Vinod


Re: [PATCH v3 6/9] dmaengine: ti-dma-crossbar: Fix of_device_id data parameter usage

2016-09-27 Thread Vinod Koul
On Wed, Sep 21, 2016 at 03:41:32PM +0300, Peter Ujfalusi wrote:
> @@ -395,7 +403,7 @@ static int ti_dra7_xbar_probe(struct platform_device 
> *pdev)
>  
>   xbar->dmarouter.dev = >dev;
>   xbar->dmarouter.route_free = ti_dra7_xbar_free;
> - xbar->dma_offset = (u32)match->data;
> + xbar->dma_offset = *(u32*)match->data;
 
we need space between u32 and *

>   mutex_init(>mutex);
>   platform_set_drvdata(pdev, xbar);
> @@ -428,7 +436,7 @@ static int ti_dma_xbar_probe(struct platform_device *pdev)
>   if (unlikely(!match))
>   return -EINVAL;
>  
> - switch ((u32)match->data) {
> + switch (*(u32*)match->data) {

here too please

-- 
~Vinod


[PATCH v3 6/9] dmaengine: ti-dma-crossbar: Fix of_device_id data parameter usage

2016-09-21 Thread Peter Ujfalusi
Use pointers to static constant variables for crossbar type and for DMA
offset configuration.

Fixes compiler warnings on 64bit architectures:

drivers/dma/ti-dma-crossbar.c: In function ‘ti_dra7_xbar_probe’:
drivers/dma/ti-dma-crossbar.c:398:21: warning: cast from pointer to integer of 
different size [-Wpointer-to-int-cast]
  xbar->dma_offset = (u32)match->data;
 ^
drivers/dma/ti-dma-crossbar.c: In function ‘ti_dma_xbar_probe’:
drivers/dma/ti-dma-crossbar.c:431:10: warning: cast from pointer to integer of 
different size [-Wpointer-to-int-cast]
  switch ((u32)match->data) {
  ^

Signed-off-by: Peter Ujfalusi 
---
 drivers/dma/ti-dma-crossbar.c | 28 ++--
 1 file changed, 18 insertions(+), 10 deletions(-)

diff --git a/drivers/dma/ti-dma-crossbar.c b/drivers/dma/ti-dma-crossbar.c
index e4f3bd1ae264..9103b1260797 100644
--- a/drivers/dma/ti-dma-crossbar.c
+++ b/drivers/dma/ti-dma-crossbar.c
@@ -18,15 +18,19 @@
 
 #define TI_XBAR_DRA7   0
 #define TI_XBAR_AM335X 1
+static const u32 ti_xbar_type[] = {
+   [TI_XBAR_DRA7] = TI_XBAR_DRA7,
+   [TI_XBAR_AM335X] = TI_XBAR_AM335X,
+};
 
 static const struct of_device_id ti_dma_xbar_match[] = {
{
.compatible = "ti,dra7-dma-crossbar",
-   .data = (void *)TI_XBAR_DRA7,
+   .data = _xbar_type[TI_XBAR_DRA7],
},
{
.compatible = "ti,am335x-edma-crossbar",
-   .data = (void *)TI_XBAR_AM335X,
+   .data = _xbar_type[TI_XBAR_AM335X],
},
{},
 };
@@ -190,9 +194,6 @@ static int ti_am335x_xbar_probe(struct platform_device 
*pdev)
 #define TI_DRA7_XBAR_OUTPUTS   127
 #define TI_DRA7_XBAR_INPUTS256
 
-#define TI_XBAR_EDMA_OFFSET0
-#define TI_XBAR_SDMA_OFFSET1
-
 struct ti_dra7_xbar_data {
void __iomem *iomem;
 
@@ -280,18 +281,25 @@ static void *ti_dra7_xbar_route_allocate(struct 
of_phandle_args *dma_spec,
return map;
 }
 
+#define TI_XBAR_EDMA_OFFSET0
+#define TI_XBAR_SDMA_OFFSET1
+static const u32 ti_dma_offset[] = {
+   [TI_XBAR_EDMA_OFFSET] = 0,
+   [TI_XBAR_SDMA_OFFSET] = 1,
+};
+
 static const struct of_device_id ti_dra7_master_match[] = {
{
.compatible = "ti,omap4430-sdma",
-   .data = (void *)TI_XBAR_SDMA_OFFSET,
+   .data = _dma_offset[TI_XBAR_SDMA_OFFSET],
},
{
.compatible = "ti,edma3",
-   .data = (void *)TI_XBAR_EDMA_OFFSET,
+   .data = _dma_offset[TI_XBAR_EDMA_OFFSET],
},
{
.compatible = "ti,edma3-tpcc",
-   .data = (void *)TI_XBAR_EDMA_OFFSET,
+   .data = _dma_offset[TI_XBAR_EDMA_OFFSET],
},
{},
 };
@@ -395,7 +403,7 @@ static int ti_dra7_xbar_probe(struct platform_device *pdev)
 
xbar->dmarouter.dev = >dev;
xbar->dmarouter.route_free = ti_dra7_xbar_free;
-   xbar->dma_offset = (u32)match->data;
+   xbar->dma_offset = *(u32*)match->data;
 
mutex_init(>mutex);
platform_set_drvdata(pdev, xbar);
@@ -428,7 +436,7 @@ static int ti_dma_xbar_probe(struct platform_device *pdev)
if (unlikely(!match))
return -EINVAL;
 
-   switch ((u32)match->data) {
+   switch (*(u32*)match->data) {
case TI_XBAR_DRA7:
ret = ti_dra7_xbar_probe(pdev);
break;
-- 
2.10.0



[PATCH v3 6/9] dmaengine: ti-dma-crossbar: Fix of_device_id data parameter usage

2016-09-21 Thread Peter Ujfalusi
Use pointers to static constant variables for crossbar type and for DMA
offset configuration.

Fixes compiler warnings on 64bit architectures:

drivers/dma/ti-dma-crossbar.c: In function ‘ti_dra7_xbar_probe’:
drivers/dma/ti-dma-crossbar.c:398:21: warning: cast from pointer to integer of 
different size [-Wpointer-to-int-cast]
  xbar->dma_offset = (u32)match->data;
 ^
drivers/dma/ti-dma-crossbar.c: In function ‘ti_dma_xbar_probe’:
drivers/dma/ti-dma-crossbar.c:431:10: warning: cast from pointer to integer of 
different size [-Wpointer-to-int-cast]
  switch ((u32)match->data) {
  ^

Signed-off-by: Peter Ujfalusi 
---
 drivers/dma/ti-dma-crossbar.c | 28 ++--
 1 file changed, 18 insertions(+), 10 deletions(-)

diff --git a/drivers/dma/ti-dma-crossbar.c b/drivers/dma/ti-dma-crossbar.c
index e4f3bd1ae264..9103b1260797 100644
--- a/drivers/dma/ti-dma-crossbar.c
+++ b/drivers/dma/ti-dma-crossbar.c
@@ -18,15 +18,19 @@
 
 #define TI_XBAR_DRA7   0
 #define TI_XBAR_AM335X 1
+static const u32 ti_xbar_type[] = {
+   [TI_XBAR_DRA7] = TI_XBAR_DRA7,
+   [TI_XBAR_AM335X] = TI_XBAR_AM335X,
+};
 
 static const struct of_device_id ti_dma_xbar_match[] = {
{
.compatible = "ti,dra7-dma-crossbar",
-   .data = (void *)TI_XBAR_DRA7,
+   .data = _xbar_type[TI_XBAR_DRA7],
},
{
.compatible = "ti,am335x-edma-crossbar",
-   .data = (void *)TI_XBAR_AM335X,
+   .data = _xbar_type[TI_XBAR_AM335X],
},
{},
 };
@@ -190,9 +194,6 @@ static int ti_am335x_xbar_probe(struct platform_device 
*pdev)
 #define TI_DRA7_XBAR_OUTPUTS   127
 #define TI_DRA7_XBAR_INPUTS256
 
-#define TI_XBAR_EDMA_OFFSET0
-#define TI_XBAR_SDMA_OFFSET1
-
 struct ti_dra7_xbar_data {
void __iomem *iomem;
 
@@ -280,18 +281,25 @@ static void *ti_dra7_xbar_route_allocate(struct 
of_phandle_args *dma_spec,
return map;
 }
 
+#define TI_XBAR_EDMA_OFFSET0
+#define TI_XBAR_SDMA_OFFSET1
+static const u32 ti_dma_offset[] = {
+   [TI_XBAR_EDMA_OFFSET] = 0,
+   [TI_XBAR_SDMA_OFFSET] = 1,
+};
+
 static const struct of_device_id ti_dra7_master_match[] = {
{
.compatible = "ti,omap4430-sdma",
-   .data = (void *)TI_XBAR_SDMA_OFFSET,
+   .data = _dma_offset[TI_XBAR_SDMA_OFFSET],
},
{
.compatible = "ti,edma3",
-   .data = (void *)TI_XBAR_EDMA_OFFSET,
+   .data = _dma_offset[TI_XBAR_EDMA_OFFSET],
},
{
.compatible = "ti,edma3-tpcc",
-   .data = (void *)TI_XBAR_EDMA_OFFSET,
+   .data = _dma_offset[TI_XBAR_EDMA_OFFSET],
},
{},
 };
@@ -395,7 +403,7 @@ static int ti_dra7_xbar_probe(struct platform_device *pdev)
 
xbar->dmarouter.dev = >dev;
xbar->dmarouter.route_free = ti_dra7_xbar_free;
-   xbar->dma_offset = (u32)match->data;
+   xbar->dma_offset = *(u32*)match->data;
 
mutex_init(>mutex);
platform_set_drvdata(pdev, xbar);
@@ -428,7 +436,7 @@ static int ti_dma_xbar_probe(struct platform_device *pdev)
if (unlikely(!match))
return -EINVAL;
 
-   switch ((u32)match->data) {
+   switch (*(u32*)match->data) {
case TI_XBAR_DRA7:
ret = ti_dra7_xbar_probe(pdev);
break;
-- 
2.10.0