blob: 2b283f68fab79e29291b66659cdd5eec2056d18f [file] [log] [blame]
Thomas Gleixnercaab2772019-06-03 07:44:50 +02001// SPDX-License-Identifier: GPL-2.0-only
Andy Gross6169a1482011-12-15 21:05:17 -06002/*
Andrew F. Davisbb5cdf82017-12-05 14:29:31 -06003 * Copyright (C) 2011 Texas Instruments Incorporated - http://www.ti.com/
Andy Gross6169a1482011-12-15 21:05:17 -06004 * Author: Rob Clark <rob.clark@linaro.org>
Andy Gross6169a1482011-12-15 21:05:17 -06005 */
6
Arnd Bergmann2d802452016-05-11 18:01:45 +02007#include <linux/seq_file.h>
8
Laurent Pinchart2d278f52015-03-05 21:31:37 +02009#include <drm/drm_crtc.h>
10#include <drm/drm_fb_helper.h>
11
Andy Gross6169a1482011-12-15 21:05:17 -060012#include "omap_drv.h"
13#include "omap_dmm_tiler.h"
14
15#ifdef CONFIG_DEBUG_FS
16
Rob Clarkf6b60362012-03-05 10:48:36 -060017static int gem_show(struct seq_file *m, void *arg)
18{
19 struct drm_info_node *node = (struct drm_info_node *) m->private;
20 struct drm_device *dev = node->minor->dev;
21 struct omap_drm_private *priv = dev->dev_private;
Rob Clarkf6b60362012-03-05 10:48:36 -060022
23 seq_printf(m, "All Objects:\n");
Daniel Vetter5117bd82018-05-25 19:39:24 +030024 mutex_lock(&priv->list_lock);
Rob Clarkf6b60362012-03-05 10:48:36 -060025 omap_gem_describe_objects(&priv->obj_list, m);
Daniel Vetter5117bd82018-05-25 19:39:24 +030026 mutex_unlock(&priv->list_lock);
Rob Clarkf6b60362012-03-05 10:48:36 -060027
Rob Clarkf6b60362012-03-05 10:48:36 -060028 return 0;
29}
30
31static int mm_show(struct seq_file *m, void *arg)
32{
33 struct drm_info_node *node = (struct drm_info_node *) m->private;
34 struct drm_device *dev = node->minor->dev;
Daniel Vetterb5c37142016-12-29 12:09:24 +010035 struct drm_printer p = drm_seq_file_printer(m);
36
37 drm_mm_print(&dev->vma_offset_manager->vm_addr_space_mm, &p);
38
39 return 0;
Rob Clarkf6b60362012-03-05 10:48:36 -060040}
41
Laurent Pincharte1c11742015-12-14 22:39:30 +020042#ifdef CONFIG_DRM_FBDEV_EMULATION
Rob Clarkf6b60362012-03-05 10:48:36 -060043static int fb_show(struct seq_file *m, void *arg)
44{
45 struct drm_info_node *node = (struct drm_info_node *) m->private;
46 struct drm_device *dev = node->minor->dev;
47 struct omap_drm_private *priv = dev->dev_private;
48 struct drm_framebuffer *fb;
Rob Clarkf6b60362012-03-05 10:48:36 -060049
50 seq_printf(m, "fbcon ");
51 omap_framebuffer_describe(priv->fbdev->fb, m);
52
Daniel Vetter4b096ac2012-12-10 21:19:18 +010053 mutex_lock(&dev->mode_config.fb_lock);
Rob Clarkf6b60362012-03-05 10:48:36 -060054 list_for_each_entry(fb, &dev->mode_config.fb_list, head) {
55 if (fb == priv->fbdev->fb)
56 continue;
57
58 seq_printf(m, "user ");
59 omap_framebuffer_describe(fb, m);
60 }
Daniel Vetter4b096ac2012-12-10 21:19:18 +010061 mutex_unlock(&dev->mode_config.fb_lock);
Rob Clarkf6b60362012-03-05 10:48:36 -060062
Rob Clarkf6b60362012-03-05 10:48:36 -060063 return 0;
64}
Laurent Pincharte1c11742015-12-14 22:39:30 +020065#endif
Rob Clarkf6b60362012-03-05 10:48:36 -060066
67/* list of debufs files that are applicable to all devices */
Andy Gross6169a1482011-12-15 21:05:17 -060068static struct drm_info_list omap_debugfs_list[] = {
Rob Clarkf6b60362012-03-05 10:48:36 -060069 {"gem", gem_show, 0},
70 {"mm", mm_show, 0},
Laurent Pincharte1c11742015-12-14 22:39:30 +020071#ifdef CONFIG_DRM_FBDEV_EMULATION
Rob Clarkf6b60362012-03-05 10:48:36 -060072 {"fb", fb_show, 0},
Laurent Pincharte1c11742015-12-14 22:39:30 +020073#endif
Rob Clarkf6b60362012-03-05 10:48:36 -060074};
75
76/* list of debugfs files that are specific to devices with dmm/tiler */
77static struct drm_info_list omap_dmm_debugfs_list[] = {
Andy Gross6169a1482011-12-15 21:05:17 -060078 {"tiler_map", tiler_map_show, 0},
79};
80
81int omap_debugfs_init(struct drm_minor *minor)
82{
Rob Clarkf6b60362012-03-05 10:48:36 -060083 struct drm_device *dev = minor->dev;
84 int ret;
85
86 ret = drm_debugfs_create_files(omap_debugfs_list,
Andy Gross6169a1482011-12-15 21:05:17 -060087 ARRAY_SIZE(omap_debugfs_list),
88 minor->debugfs_root, minor);
Rob Clarkf6b60362012-03-05 10:48:36 -060089
90 if (ret) {
91 dev_err(dev->dev, "could not install omap_debugfs_list\n");
92 return ret;
93 }
94
Andy Gross132390c2012-03-05 10:48:37 -060095 if (dmm_is_available())
96 ret = drm_debugfs_create_files(omap_dmm_debugfs_list,
97 ARRAY_SIZE(omap_dmm_debugfs_list),
98 minor->debugfs_root, minor);
Rob Clarkf6b60362012-03-05 10:48:36 -060099
100 if (ret) {
101 dev_err(dev->dev, "could not install omap_dmm_debugfs_list\n");
102 return ret;
103 }
104
105 return ret;
Andy Gross6169a1482011-12-15 21:05:17 -0600106}
107
Andy Gross6169a1482011-12-15 21:05:17 -0600108#endif