forked from Minki/linux
drm/vc4: Use drm_printer for the debugfs and runtime bo stats output.
Now I can extend the stats without more copy and pasting between the two. Signed-off-by: Eric Anholt <eric@anholt.net> Link: https://patchwork.freedesktop.org/patch/msgid/20190220210343.28157-4-eric@anholt.net Reviewed-by: Paul Kocialkowski <paul.kocialkowski@bootlin.com>
This commit is contained in:
parent
3a3fe6e766
commit
13f0ec3417
@ -40,7 +40,7 @@ static bool is_user_label(int label)
|
|||||||
return label >= VC4_BO_TYPE_COUNT;
|
return label >= VC4_BO_TYPE_COUNT;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void vc4_bo_stats_dump(struct vc4_dev *vc4)
|
static void vc4_bo_stats_print(struct drm_printer *p, struct vc4_dev *vc4)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
@ -48,21 +48,21 @@ static void vc4_bo_stats_dump(struct vc4_dev *vc4)
|
|||||||
if (!vc4->bo_labels[i].num_allocated)
|
if (!vc4->bo_labels[i].num_allocated)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
DRM_INFO("%30s: %6dkb BOs (%d)\n",
|
drm_printf(p, "%30s: %6dkb BOs (%d)\n",
|
||||||
vc4->bo_labels[i].name,
|
vc4->bo_labels[i].name,
|
||||||
vc4->bo_labels[i].size_allocated / 1024,
|
vc4->bo_labels[i].size_allocated / 1024,
|
||||||
vc4->bo_labels[i].num_allocated);
|
vc4->bo_labels[i].num_allocated);
|
||||||
}
|
}
|
||||||
|
|
||||||
mutex_lock(&vc4->purgeable.lock);
|
mutex_lock(&vc4->purgeable.lock);
|
||||||
if (vc4->purgeable.num)
|
if (vc4->purgeable.num)
|
||||||
DRM_INFO("%30s: %6zdkb BOs (%d)\n", "userspace BO cache",
|
drm_printf(p, "%30s: %6zdkb BOs (%d)\n", "userspace BO cache",
|
||||||
vc4->purgeable.size / 1024, vc4->purgeable.num);
|
vc4->purgeable.size / 1024, vc4->purgeable.num);
|
||||||
|
|
||||||
if (vc4->purgeable.purged_num)
|
if (vc4->purgeable.purged_num)
|
||||||
DRM_INFO("%30s: %6zdkb BOs (%d)\n", "total purged BO",
|
drm_printf(p, "%30s: %6zdkb BOs (%d)\n", "total purged BO",
|
||||||
vc4->purgeable.purged_size / 1024,
|
vc4->purgeable.purged_size / 1024,
|
||||||
vc4->purgeable.purged_num);
|
vc4->purgeable.purged_num);
|
||||||
mutex_unlock(&vc4->purgeable.lock);
|
mutex_unlock(&vc4->purgeable.lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -72,30 +72,9 @@ int vc4_bo_stats_debugfs(struct seq_file *m, void *unused)
|
|||||||
struct drm_info_node *node = (struct drm_info_node *)m->private;
|
struct drm_info_node *node = (struct drm_info_node *)m->private;
|
||||||
struct drm_device *dev = node->minor->dev;
|
struct drm_device *dev = node->minor->dev;
|
||||||
struct vc4_dev *vc4 = to_vc4_dev(dev);
|
struct vc4_dev *vc4 = to_vc4_dev(dev);
|
||||||
int i;
|
struct drm_printer p = drm_seq_file_printer(m);
|
||||||
|
|
||||||
mutex_lock(&vc4->bo_lock);
|
vc4_bo_stats_print(&p, vc4);
|
||||||
for (i = 0; i < vc4->num_labels; i++) {
|
|
||||||
if (!vc4->bo_labels[i].num_allocated)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
seq_printf(m, "%30s: %6dkb BOs (%d)\n",
|
|
||||||
vc4->bo_labels[i].name,
|
|
||||||
vc4->bo_labels[i].size_allocated / 1024,
|
|
||||||
vc4->bo_labels[i].num_allocated);
|
|
||||||
}
|
|
||||||
mutex_unlock(&vc4->bo_lock);
|
|
||||||
|
|
||||||
mutex_lock(&vc4->purgeable.lock);
|
|
||||||
if (vc4->purgeable.num)
|
|
||||||
seq_printf(m, "%30s: %6zdkb BOs (%d)\n", "userspace BO cache",
|
|
||||||
vc4->purgeable.size / 1024, vc4->purgeable.num);
|
|
||||||
|
|
||||||
if (vc4->purgeable.purged_num)
|
|
||||||
seq_printf(m, "%30s: %6zdkb BOs (%d)\n", "total purged BO",
|
|
||||||
vc4->purgeable.purged_size / 1024,
|
|
||||||
vc4->purgeable.purged_num);
|
|
||||||
mutex_unlock(&vc4->purgeable.lock);
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -475,8 +454,9 @@ struct vc4_bo *vc4_bo_create(struct drm_device *dev, size_t unaligned_size,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (IS_ERR(cma_obj)) {
|
if (IS_ERR(cma_obj)) {
|
||||||
|
struct drm_printer p = drm_info_printer(vc4->dev->dev);
|
||||||
DRM_ERROR("Failed to allocate from CMA:\n");
|
DRM_ERROR("Failed to allocate from CMA:\n");
|
||||||
vc4_bo_stats_dump(vc4);
|
vc4_bo_stats_print(&p, vc4);
|
||||||
return ERR_PTR(-ENOMEM);
|
return ERR_PTR(-ENOMEM);
|
||||||
}
|
}
|
||||||
bo = to_vc4_bo(&cma_obj->base);
|
bo = to_vc4_bo(&cma_obj->base);
|
||||||
|
Loading…
Reference in New Issue
Block a user