/* * 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. */ bool dm_fdt_pre_reloc(const void *blob, int offset); #endif