|
@@ -2882,7 +2882,7 @@ static void mtree_print_mr_owner(const MemoryRegion *mr)
|
|
static void mtree_print_mr(const MemoryRegion *mr, unsigned int level,
|
|
static void mtree_print_mr(const MemoryRegion *mr, unsigned int level,
|
|
hwaddr base,
|
|
hwaddr base,
|
|
MemoryRegionListHead *alias_print_queue,
|
|
MemoryRegionListHead *alias_print_queue,
|
|
- bool owner)
|
|
|
|
|
|
+ bool owner, bool display_disabled)
|
|
{
|
|
{
|
|
MemoryRegionList *new_ml, *ml, *next_ml;
|
|
MemoryRegionList *new_ml, *ml, *next_ml;
|
|
MemoryRegionListHead submr_print_queue;
|
|
MemoryRegionListHead submr_print_queue;
|
|
@@ -2894,10 +2894,6 @@ static void mtree_print_mr(const MemoryRegion *mr, unsigned int level,
|
|
return;
|
|
return;
|
|
}
|
|
}
|
|
|
|
|
|
- for (i = 0; i < level; i++) {
|
|
|
|
- qemu_printf(MTREE_INDENT);
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
cur_start = base + mr->addr;
|
|
cur_start = base + mr->addr;
|
|
cur_end = cur_start + MR_SIZE(mr->size);
|
|
cur_end = cur_start + MR_SIZE(mr->size);
|
|
|
|
|
|
@@ -2926,35 +2922,46 @@ static void mtree_print_mr(const MemoryRegion *mr, unsigned int level,
|
|
ml->mr = mr->alias;
|
|
ml->mr = mr->alias;
|
|
QTAILQ_INSERT_TAIL(alias_print_queue, ml, mrqueue);
|
|
QTAILQ_INSERT_TAIL(alias_print_queue, ml, mrqueue);
|
|
}
|
|
}
|
|
- qemu_printf(TARGET_FMT_plx "-" TARGET_FMT_plx
|
|
|
|
- " (prio %d, %s%s): alias %s @%s " TARGET_FMT_plx
|
|
|
|
- "-" TARGET_FMT_plx "%s",
|
|
|
|
- cur_start, cur_end,
|
|
|
|
- mr->priority,
|
|
|
|
- mr->nonvolatile ? "nv-" : "",
|
|
|
|
- memory_region_type((MemoryRegion *)mr),
|
|
|
|
- memory_region_name(mr),
|
|
|
|
- memory_region_name(mr->alias),
|
|
|
|
- mr->alias_offset,
|
|
|
|
- mr->alias_offset + MR_SIZE(mr->size),
|
|
|
|
- mr->enabled ? "" : " [disabled]");
|
|
|
|
- if (owner) {
|
|
|
|
- mtree_print_mr_owner(mr);
|
|
|
|
|
|
+ if (mr->enabled || display_disabled) {
|
|
|
|
+ for (i = 0; i < level; i++) {
|
|
|
|
+ qemu_printf(MTREE_INDENT);
|
|
|
|
+ }
|
|
|
|
+ qemu_printf(TARGET_FMT_plx "-" TARGET_FMT_plx
|
|
|
|
+ " (prio %d, %s%s): alias %s @%s " TARGET_FMT_plx
|
|
|
|
+ "-" TARGET_FMT_plx "%s",
|
|
|
|
+ cur_start, cur_end,
|
|
|
|
+ mr->priority,
|
|
|
|
+ mr->nonvolatile ? "nv-" : "",
|
|
|
|
+ memory_region_type((MemoryRegion *)mr),
|
|
|
|
+ memory_region_name(mr),
|
|
|
|
+ memory_region_name(mr->alias),
|
|
|
|
+ mr->alias_offset,
|
|
|
|
+ mr->alias_offset + MR_SIZE(mr->size),
|
|
|
|
+ mr->enabled ? "" : " [disabled]");
|
|
|
|
+ if (owner) {
|
|
|
|
+ mtree_print_mr_owner(mr);
|
|
|
|
+ }
|
|
|
|
+ qemu_printf("\n");
|
|
}
|
|
}
|
|
} else {
|
|
} else {
|
|
- qemu_printf(TARGET_FMT_plx "-" TARGET_FMT_plx
|
|
|
|
- " (prio %d, %s%s): %s%s",
|
|
|
|
- cur_start, cur_end,
|
|
|
|
- mr->priority,
|
|
|
|
- mr->nonvolatile ? "nv-" : "",
|
|
|
|
- memory_region_type((MemoryRegion *)mr),
|
|
|
|
- memory_region_name(mr),
|
|
|
|
- mr->enabled ? "" : " [disabled]");
|
|
|
|
- if (owner) {
|
|
|
|
- mtree_print_mr_owner(mr);
|
|
|
|
|
|
+ if (mr->enabled || display_disabled) {
|
|
|
|
+ for (i = 0; i < level; i++) {
|
|
|
|
+ qemu_printf(MTREE_INDENT);
|
|
|
|
+ }
|
|
|
|
+ qemu_printf(TARGET_FMT_plx "-" TARGET_FMT_plx
|
|
|
|
+ " (prio %d, %s%s): %s%s",
|
|
|
|
+ cur_start, cur_end,
|
|
|
|
+ mr->priority,
|
|
|
|
+ mr->nonvolatile ? "nv-" : "",
|
|
|
|
+ memory_region_type((MemoryRegion *)mr),
|
|
|
|
+ memory_region_name(mr),
|
|
|
|
+ mr->enabled ? "" : " [disabled]");
|
|
|
|
+ if (owner) {
|
|
|
|
+ mtree_print_mr_owner(mr);
|
|
|
|
+ }
|
|
|
|
+ qemu_printf("\n");
|
|
}
|
|
}
|
|
}
|
|
}
|
|
- qemu_printf("\n");
|
|
|
|
|
|
|
|
QTAILQ_INIT(&submr_print_queue);
|
|
QTAILQ_INIT(&submr_print_queue);
|
|
|
|
|
|
@@ -2977,7 +2984,7 @@ static void mtree_print_mr(const MemoryRegion *mr, unsigned int level,
|
|
|
|
|
|
QTAILQ_FOREACH(ml, &submr_print_queue, mrqueue) {
|
|
QTAILQ_FOREACH(ml, &submr_print_queue, mrqueue) {
|
|
mtree_print_mr(ml->mr, level + 1, cur_start,
|
|
mtree_print_mr(ml->mr, level + 1, cur_start,
|
|
- alias_print_queue, owner);
|
|
|
|
|
|
+ alias_print_queue, owner, display_disabled);
|
|
}
|
|
}
|
|
|
|
|
|
QTAILQ_FOREACH_SAFE(ml, &submr_print_queue, mrqueue, next_ml) {
|
|
QTAILQ_FOREACH_SAFE(ml, &submr_print_queue, mrqueue, next_ml) {
|
|
@@ -3088,7 +3095,7 @@ static gboolean mtree_info_flatview_free(gpointer key, gpointer value,
|
|
return true;
|
|
return true;
|
|
}
|
|
}
|
|
|
|
|
|
-void mtree_info(bool flatview, bool dispatch_tree, bool owner)
|
|
|
|
|
|
+void mtree_info(bool flatview, bool dispatch_tree, bool owner, bool disabled)
|
|
{
|
|
{
|
|
MemoryRegionListHead ml_head;
|
|
MemoryRegionListHead ml_head;
|
|
MemoryRegionList *ml, *ml2;
|
|
MemoryRegionList *ml, *ml2;
|
|
@@ -3136,14 +3143,14 @@ void mtree_info(bool flatview, bool dispatch_tree, bool owner)
|
|
|
|
|
|
QTAILQ_FOREACH(as, &address_spaces, address_spaces_link) {
|
|
QTAILQ_FOREACH(as, &address_spaces, address_spaces_link) {
|
|
qemu_printf("address-space: %s\n", as->name);
|
|
qemu_printf("address-space: %s\n", as->name);
|
|
- mtree_print_mr(as->root, 1, 0, &ml_head, owner);
|
|
|
|
|
|
+ mtree_print_mr(as->root, 1, 0, &ml_head, owner, disabled);
|
|
qemu_printf("\n");
|
|
qemu_printf("\n");
|
|
}
|
|
}
|
|
|
|
|
|
/* print aliased regions */
|
|
/* print aliased regions */
|
|
QTAILQ_FOREACH(ml, &ml_head, mrqueue) {
|
|
QTAILQ_FOREACH(ml, &ml_head, mrqueue) {
|
|
qemu_printf("memory-region: %s\n", memory_region_name(ml->mr));
|
|
qemu_printf("memory-region: %s\n", memory_region_name(ml->mr));
|
|
- mtree_print_mr(ml->mr, 1, 0, &ml_head, owner);
|
|
|
|
|
|
+ mtree_print_mr(ml->mr, 1, 0, &ml_head, owner, disabled);
|
|
qemu_printf("\n");
|
|
qemu_printf("\n");
|
|
}
|
|
}
|
|
|
|
|