1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677 |
- /*
- * Copyright (c) 2013 Google, Inc
- *
- * SPDX-License-Identifier: GPL-2.0+
- */
- #ifndef __DM_UTIL_H
- #define __DM_UTIL_H
- #ifdef CONFIG_DM_WARN
- void dm_warn(const char *fmt, ...);
- #else
- static inline void dm_warn(const char *fmt, ...)
- {
- }
- #endif
- #ifdef DEBUG
- void dm_dbg(const char *fmt, ...);
- #else
- static inline void dm_dbg(const char *fmt, ...)
- {
- }
- #endif
- struct list_head;
- /**
- * list_count_items() - Count number of items in a list
- *
- * @param head: Head of list
- * @return number of items, or 0 if empty
- */
- int list_count_items(struct list_head *head);
- /* Dump out a tree of all devices */
- void dm_dump_all(void);
- /* Dump out a list of uclasses and their devices */
- void dm_dump_uclass(void);
- #ifdef CONFIG_DEBUG_DEVRES
- /* Dump out a list of device resources */
- void dm_dump_devres(void);
- #else
- static inline void dm_dump_devres(void)
- {
- }
- #endif
- /**
- * Check if a dt node should be or was bound before relocation.
- *
- * Devicetree nodes can be marked as needed to be bound
- * in the loader stages via special devicetree properties.
- *
- * Before relocation this function can be used to check if nodes
- * are required in either SPL or TPL stages.
- *
- * After relocation and jumping into the real U-Boot binary
- * it is possible to determine if a node was bound in one of
- * SPL/TPL stages.
- *
- * There are 3 settings currently in use
- * -
- * - u-boot,dm-pre-reloc: legacy and indicates any of TPL or SPL
- * Existing platforms only use it to indicate nodes needee in
- * SPL. Should probably be replaced by u-boot,dm-spl for
- * existing platforms.
- * @blob: devicetree
- * @offset: node offset
- *
- * Returns true if node is needed in SPL/TL, false otherwise.
- */
- int dm_fdt_pre_reloc(const void *blob, int offset);
- #endif
|