xref: /rk3399_rockchip-uboot/drivers/core/dump.c (revision d9da4b44281a549e13a5f3a136d1ffc16cd52f57)
1304fbef1SSimon Glass /*
2304fbef1SSimon Glass  * Copyright (c) 2015 Google, Inc
3304fbef1SSimon Glass  *
4304fbef1SSimon Glass  * SPDX-License-Identifier:	GPL-2.0+
5304fbef1SSimon Glass  */
6304fbef1SSimon Glass 
7304fbef1SSimon Glass #include <common.h>
8304fbef1SSimon Glass #include <dm.h>
9304fbef1SSimon Glass #include <mapmem.h>
10304fbef1SSimon Glass #include <dm/root.h>
11fce136aaSMasahiro Yamada #include <dm/util.h>
12304fbef1SSimon Glass 
show_devices(struct udevice * dev,int depth,int last_flag)13304fbef1SSimon Glass static void show_devices(struct udevice *dev, int depth, int last_flag)
14304fbef1SSimon Glass {
15304fbef1SSimon Glass 	int i, is_last;
16304fbef1SSimon Glass 	struct udevice *child;
17304fbef1SSimon Glass 
18304fbef1SSimon Glass 	/* print the first 11 characters to not break the tree-format. */
194ad73f9eSJoseph Chen 	printf(" %08lx    %-10.10s [ %c ]   %-25.25s  ",
204ad73f9eSJoseph Chen 	       (ulong)dev, dev->uclass->uc_drv->name,
21ae9ecb97SSimon Glass 	       dev->flags & DM_FLAG_ACTIVATED ? '+' : ' ', dev->driver->name);
22304fbef1SSimon Glass 
23304fbef1SSimon Glass 	for (i = depth; i >= 0; i--) {
24304fbef1SSimon Glass 		is_last = (last_flag >> i) & 1;
25304fbef1SSimon Glass 		if (i) {
26304fbef1SSimon Glass 			if (is_last)
27304fbef1SSimon Glass 				printf("    ");
28304fbef1SSimon Glass 			else
29304fbef1SSimon Glass 				printf("|   ");
30304fbef1SSimon Glass 		} else {
31304fbef1SSimon Glass 			if (is_last)
32304fbef1SSimon Glass 				printf("`-- ");
33304fbef1SSimon Glass 			else
34304fbef1SSimon Glass 				printf("|-- ");
35304fbef1SSimon Glass 		}
36304fbef1SSimon Glass 	}
37304fbef1SSimon Glass 
38*d9da4b44SJoseph Chen #ifdef CONFIG_USING_KERNEL_DTB_V2
39*d9da4b44SJoseph Chen 	printf("%s %s\n", dev->name, dev->flags & DM_FLAG_KNRL_DTB ? "" : "*");
40*d9da4b44SJoseph Chen #else
41*d9da4b44SJoseph Chen 	int pre_reloc, remained;
42659e640aSJoseph Chen 
43*d9da4b44SJoseph Chen 	pre_reloc = dev->flags & DM_FLAG_KNRL_DTB ? 0 : 1;
44*d9da4b44SJoseph Chen 	remained = pre_reloc ? !list_empty(&dev->uclass_node) : 0;
45659e640aSJoseph Chen 	printf("%s %s%s\n", dev->name, pre_reloc ? "*" : "", remained ? "*" : "");
46*d9da4b44SJoseph Chen #endif
47304fbef1SSimon Glass 	list_for_each_entry(child, &dev->child_head, sibling_node) {
48304fbef1SSimon Glass 		is_last = list_is_last(&child->sibling_node, &dev->child_head);
49304fbef1SSimon Glass 		show_devices(child, depth + 1, (last_flag << 1) | is_last);
50304fbef1SSimon Glass 	}
51304fbef1SSimon Glass }
52304fbef1SSimon Glass 
dm_dump_all(void)53304fbef1SSimon Glass void dm_dump_all(void)
54304fbef1SSimon Glass {
55304fbef1SSimon Glass 	struct udevice *root;
56304fbef1SSimon Glass 
57304fbef1SSimon Glass 	root = dm_root();
58304fbef1SSimon Glass 	if (root) {
594ad73f9eSJoseph Chen 		printf(" Addr        Class      Probed    Driver                   Name\n");
604ad73f9eSJoseph Chen 		printf("-------------------------------------------------------------------------\n");
61304fbef1SSimon Glass 		show_devices(root, -1, 0);
62304fbef1SSimon Glass 	}
63304fbef1SSimon Glass }
64304fbef1SSimon Glass 
65304fbef1SSimon Glass /**
66304fbef1SSimon Glass  * dm_display_line() - Display information about a single device
67304fbef1SSimon Glass  *
68304fbef1SSimon Glass  * Displays a single line of information with an option prefix
69304fbef1SSimon Glass  *
70304fbef1SSimon Glass  * @dev:	Device to display
71304fbef1SSimon Glass  */
dm_display_line(struct udevice * dev)72304fbef1SSimon Glass static void dm_display_line(struct udevice *dev)
73304fbef1SSimon Glass {
74*d9da4b44SJoseph Chen 	printf("  [ %c ] %s @ %08lx",
75d5cc49d9SJoseph Chen 	       dev->flags & DM_FLAG_ACTIVATED ? '+' : ' ',
76304fbef1SSimon Glass 	       dev->name, (ulong)map_to_sysmem(dev));
77304fbef1SSimon Glass 	if (dev->seq != -1 || dev->req_seq != -1)
78304fbef1SSimon Glass 		printf(", seq %d, (req %d)", dev->seq, dev->req_seq);
79*d9da4b44SJoseph Chen 	if (dev->driver->id == UCLASS_BLK) {
80*d9da4b44SJoseph Chen 		struct blk_desc *desc = dev_get_uclass_platdata(dev);
81*d9da4b44SJoseph Chen 		printf(" | %s%d", blk_get_if_type_name(desc->if_type), desc->devnum);
82*d9da4b44SJoseph Chen 	}
83*d9da4b44SJoseph Chen 	printf(" %c", dev->flags & DM_FLAG_KNRL_DTB ? ' ' : '*');
84304fbef1SSimon Glass 	puts("\n");
85304fbef1SSimon Glass }
86304fbef1SSimon Glass 
dm_dump_uclass(void)87304fbef1SSimon Glass void dm_dump_uclass(void)
88304fbef1SSimon Glass {
89304fbef1SSimon Glass 	struct uclass *uc;
90304fbef1SSimon Glass 	int ret;
91304fbef1SSimon Glass 	int id;
92304fbef1SSimon Glass 
93304fbef1SSimon Glass 	for (id = 0; id < UCLASS_COUNT; id++) {
94304fbef1SSimon Glass 		struct udevice *dev;
95304fbef1SSimon Glass 
96304fbef1SSimon Glass 		ret = uclass_get(id, &uc);
97304fbef1SSimon Glass 		if (ret)
98304fbef1SSimon Glass 			continue;
99304fbef1SSimon Glass 
100304fbef1SSimon Glass 		printf("uclass %d: %s\n", id, uc->uc_drv->name);
101304fbef1SSimon Glass 		if (list_empty(&uc->dev_head))
102304fbef1SSimon Glass 			continue;
103304fbef1SSimon Glass 		list_for_each_entry(dev, &uc->dev_head, uclass_node) {
104304fbef1SSimon Glass 			dm_display_line(dev);
105304fbef1SSimon Glass 		}
106304fbef1SSimon Glass 		puts("\n");
107304fbef1SSimon Glass 	}
108304fbef1SSimon Glass }
109