mirror of
https://github.com/Fishwaldo/u-boot.git
synced 2025-03-31 19:41:46 +00:00
core: Add {ofnode, dev}_translate_address functions
Reviewed-by: Simon Glass <sjg@chromium.org> Signed-off-by: Mario Six <mario.six@gdsys.cc>
This commit is contained in:
parent
83a462a5e3
commit
147c607448
4 changed files with 43 additions and 0 deletions
|
@ -649,3 +649,11 @@ int ofnode_read_resource_byname(ofnode node, const char *name,
|
||||||
|
|
||||||
return ofnode_read_resource(node, index, res);
|
return ofnode_read_resource(node, index, res);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
u64 ofnode_translate_address(ofnode node, const fdt32_t *in_addr)
|
||||||
|
{
|
||||||
|
if (ofnode_is_np(node))
|
||||||
|
return of_translate_address(ofnode_to_np(node), in_addr);
|
||||||
|
else
|
||||||
|
return fdt_translate_address(gd->fdt_blob, ofnode_to_offset(node), in_addr);
|
||||||
|
}
|
||||||
|
|
|
@ -195,3 +195,8 @@ int dev_read_resource_byname(struct udevice *dev, const char *name,
|
||||||
{
|
{
|
||||||
return ofnode_read_resource_byname(dev_ofnode(dev), name, res);
|
return ofnode_read_resource_byname(dev_ofnode(dev), name, res);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
u64 dev_translate_address(struct udevice *dev, const fdt32_t *in_addr)
|
||||||
|
{
|
||||||
|
return ofnode_translate_address(dev_ofnode(dev), in_addr);
|
||||||
|
}
|
||||||
|
|
|
@ -652,4 +652,17 @@ int ofnode_read_resource_byname(ofnode node, const char *name,
|
||||||
ofnode_valid(node); \
|
ofnode_valid(node); \
|
||||||
node = ofnode_next_subnode(node))
|
node = ofnode_next_subnode(node))
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ofnode_translate_address() - Tranlate a device-tree address
|
||||||
|
*
|
||||||
|
* Translate an address from the device-tree into a CPU physical address. This
|
||||||
|
* function walks up the tree and applies the various bus mappings along the
|
||||||
|
* way.
|
||||||
|
*
|
||||||
|
* @ofnode: Device tree node giving the context in which to translate the
|
||||||
|
* address
|
||||||
|
* @in_addr: pointer to the address to translate
|
||||||
|
* @return the translated address; OF_BAD_ADDR on error
|
||||||
|
*/
|
||||||
|
u64 ofnode_translate_address(ofnode node, const fdt32_t *in_addr);
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -410,6 +410,18 @@ int dev_read_resource(struct udevice *dev, uint index, struct resource *res);
|
||||||
int dev_read_resource_byname(struct udevice *dev, const char *name,
|
int dev_read_resource_byname(struct udevice *dev, const char *name,
|
||||||
struct resource *res);
|
struct resource *res);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* dev_translate_address() - Tranlate a device-tree address
|
||||||
|
*
|
||||||
|
* Translate an address from the device-tree into a CPU physical address. This
|
||||||
|
* function walks up the tree and applies the various bus mappings along the
|
||||||
|
* way.
|
||||||
|
*
|
||||||
|
* @dev: device giving the context in which to translate the address
|
||||||
|
* @in_addr: pointer to the address to translate
|
||||||
|
* @return the translated address; OF_BAD_ADDR on error
|
||||||
|
*/
|
||||||
|
u64 dev_translate_address(struct udevice *dev, const fdt32_t *in_addr);
|
||||||
#else /* CONFIG_DM_DEV_READ_INLINE is enabled */
|
#else /* CONFIG_DM_DEV_READ_INLINE is enabled */
|
||||||
|
|
||||||
static inline int dev_read_u32_default(struct udevice *dev,
|
static inline int dev_read_u32_default(struct udevice *dev,
|
||||||
|
@ -582,6 +594,11 @@ static inline int dev_read_resource_byname(struct udevice *dev,
|
||||||
return ofnode_read_resource_byname(dev_ofnode(dev), name, res);
|
return ofnode_read_resource_byname(dev_ofnode(dev), name, res);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline u64 dev_translate_address(struct udevice *dev, const fdt32_t *in_addr)
|
||||||
|
{
|
||||||
|
return ofnode_translate_address(dev_ofnode(dev), in_addr);
|
||||||
|
}
|
||||||
|
|
||||||
#endif /* CONFIG_DM_DEV_READ_INLINE */
|
#endif /* CONFIG_DM_DEV_READ_INLINE */
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
Loading…
Add table
Reference in a new issue