public inbox for u-boot@lists.denx.de
 help / color / mirror / Atom feed
* [U-Boot] [PATCH] net: altera_tse: get numbers of fdt address and size cells
@ 2015-11-04 12:28 Thomas Chou
  2015-11-04 18:24 ` Joe Hershberger
  2015-11-06  1:30 ` Thomas Chou
  0 siblings, 2 replies; 3+ messages in thread
From: Thomas Chou @ 2015-11-04 12:28 UTC (permalink / raw)
  To: u-boot

Get numbers of fdt address and size cells in altera_tse_probe(),
thereby remove the assumption of one address cell and one size
cell.

Signed-off-by: Thomas Chou <thomas@wytron.com.tw>
---
 drivers/net/altera_tse.c | 14 ++++++++------
 1 file changed, 8 insertions(+), 6 deletions(-)

diff --git a/drivers/net/altera_tse.c b/drivers/net/altera_tse.c
index 394503f..b2002f4 100644
--- a/drivers/net/altera_tse.c
+++ b/drivers/net/altera_tse.c
@@ -409,20 +409,22 @@ static int altera_tse_probe(struct udevice *dev)
 {
 	struct eth_pdata *pdata = dev_get_platdata(dev);
 	struct altera_tse_priv *priv = dev_get_priv(dev);
-	const void *blob = gd->fdt_blob;
+	void *blob = (void *)gd->fdt_blob;
 	int node = dev->of_offset;
 	const char *list, *end;
 	const fdt32_t *cell;
 	void *base, *desc_mem = NULL;
 	unsigned long addr, size;
+	int parent, addrc, sizec;
 	int len, idx;
 	int ret;
 
 	/*
-	 * decode regs, assume address-cells and size-cells are both one.
-	 * there are multiple reg tuples, and they need to match with
-	 * reg-names.
+	 * decode regs. there are multiple reg tuples, and they need to
+	 * match with reg-names.
 	 */
+	parent = fdt_parent_offset(blob, node);
+	of_bus_default_count_cells(blob, parent, &addrc, &sizec);
 	list = fdt_getprop(blob, node, "reg-names", &len);
 	if (!list)
 		return -ENOENT;
@@ -434,7 +436,7 @@ static int altera_tse_probe(struct udevice *dev)
 	while (list < end) {
 		addr = fdt_translate_address((void *)blob,
 					     node, cell + idx);
-		size = fdt_addr_to_cpu(cell[idx + 1]);
+		size = fdt_addr_to_cpu(cell[idx + addrc]);
 		base = ioremap(addr, size);
 		len = strlen(list);
 		if (strcmp(list, "control_port") == 0)
@@ -445,7 +447,7 @@ static int altera_tse_probe(struct udevice *dev)
 			priv->sgdma_tx = base;
 		else if (strcmp(list, "s1") == 0)
 			desc_mem = base;
-		idx += 2;
+		idx += addrc + sizec;
 		list += (len + 1);
 	}
 	/* decode fifo depth */
-- 
2.5.0

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

* [U-Boot] [PATCH] net: altera_tse: get numbers of fdt address and size cells
  2015-11-04 12:28 [U-Boot] [PATCH] net: altera_tse: get numbers of fdt address and size cells Thomas Chou
@ 2015-11-04 18:24 ` Joe Hershberger
  2015-11-06  1:30 ` Thomas Chou
  1 sibling, 0 replies; 3+ messages in thread
From: Joe Hershberger @ 2015-11-04 18:24 UTC (permalink / raw)
  To: u-boot

Hi Thomas,

On Wed, Nov 4, 2015 at 6:28 AM, Thomas Chou <thomas@wytron.com.tw> wrote:
> Get numbers of fdt address and size cells in altera_tse_probe(),
> thereby remove the assumption of one address cell and one size
> cell.
>
> Signed-off-by: Thomas Chou <thomas@wytron.com.tw>
> ---

Acked-by: Joe Hershberger <joe.hershberger@ni.com>

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

* [U-Boot] [PATCH] net: altera_tse: get numbers of fdt address and size cells
  2015-11-04 12:28 [U-Boot] [PATCH] net: altera_tse: get numbers of fdt address and size cells Thomas Chou
  2015-11-04 18:24 ` Joe Hershberger
@ 2015-11-06  1:30 ` Thomas Chou
  1 sibling, 0 replies; 3+ messages in thread
From: Thomas Chou @ 2015-11-06  1:30 UTC (permalink / raw)
  To: u-boot



On 2015?11?04? 20:28, Thomas Chou wrote:
> Get numbers of fdt address and size cells in altera_tse_probe(),
> thereby remove the assumption of one address cell and one size
> cell.
>
> Signed-off-by: Thomas Chou <thomas@wytron.com.tw>
> ---
>   drivers/net/altera_tse.c | 14 ++++++++------
>   1 file changed, 8 insertions(+), 6 deletions(-)
>

Applied to u-boot-nios.

> diff --git a/drivers/net/altera_tse.c b/drivers/net/altera_tse.c
> index 394503f..b2002f4 100644
> --- a/drivers/net/altera_tse.c
> +++ b/drivers/net/altera_tse.c
> @@ -409,20 +409,22 @@ static int altera_tse_probe(struct udevice *dev)
>   {
>   	struct eth_pdata *pdata = dev_get_platdata(dev);
>   	struct altera_tse_priv *priv = dev_get_priv(dev);
> -	const void *blob = gd->fdt_blob;
> +	void *blob = (void *)gd->fdt_blob;
>   	int node = dev->of_offset;
>   	const char *list, *end;
>   	const fdt32_t *cell;
>   	void *base, *desc_mem = NULL;
>   	unsigned long addr, size;
> +	int parent, addrc, sizec;
>   	int len, idx;
>   	int ret;
>
>   	/*
> -	 * decode regs, assume address-cells and size-cells are both one.
> -	 * there are multiple reg tuples, and they need to match with
> -	 * reg-names.
> +	 * decode regs. there are multiple reg tuples, and they need to
> +	 * match with reg-names.
>   	 */
> +	parent = fdt_parent_offset(blob, node);
> +	of_bus_default_count_cells(blob, parent, &addrc, &sizec);
>   	list = fdt_getprop(blob, node, "reg-names", &len);
>   	if (!list)
>   		return -ENOENT;
> @@ -434,7 +436,7 @@ static int altera_tse_probe(struct udevice *dev)
>   	while (list < end) {
>   		addr = fdt_translate_address((void *)blob,
>   					     node, cell + idx);
> -		size = fdt_addr_to_cpu(cell[idx + 1]);
> +		size = fdt_addr_to_cpu(cell[idx + addrc]);
>   		base = ioremap(addr, size);
>   		len = strlen(list);
>   		if (strcmp(list, "control_port") == 0)
> @@ -445,7 +447,7 @@ static int altera_tse_probe(struct udevice *dev)
>   			priv->sgdma_tx = base;
>   		else if (strcmp(list, "s1") == 0)
>   			desc_mem = base;
> -		idx += 2;
> +		idx += addrc + sizec;
>   		list += (len + 1);
>   	}
>   	/* decode fifo depth */
>

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

end of thread, other threads:[~2015-11-06  1:30 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2015-11-04 12:28 [U-Boot] [PATCH] net: altera_tse: get numbers of fdt address and size cells Thomas Chou
2015-11-04 18:24 ` Joe Hershberger
2015-11-06  1:30 ` Thomas Chou

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox