* [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