cregit-Linux how code gets into the kernel

Release 4.11 drivers/gpu/drm/omapdrm/omap_debugfs.c

/*
 * drivers/gpu/drm/omapdrm/omap_debugfs.c
 *
 * Copyright (C) 2011 Texas Instruments
 * Author: Rob Clark <rob.clark@linaro.org>
 *
 * This program is free software; you can redistribute it and/or modify it
 * under the terms of the GNU General Public License version 2 as published by
 * the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
 * more details.
 *
 * You should have received a copy of the GNU General Public License along with
 * this program.  If not, see <http://www.gnu.org/licenses/>.
 */

#include <linux/seq_file.h>

#include <drm/drm_crtc.h>
#include <drm/drm_fb_helper.h>

#include "omap_drv.h"
#include "omap_dmm_tiler.h"

#ifdef CONFIG_DEBUG_FS


static int gem_show(struct seq_file *m, void *arg) { struct drm_info_node *node = (struct drm_info_node *) m->private; struct drm_device *dev = node->minor->dev; struct omap_drm_private *priv = dev->dev_private; int ret; ret = mutex_lock_interruptible(&dev->struct_mutex); if (ret) return ret; seq_printf(m, "All Objects:\n"); omap_gem_describe_objects(&priv->obj_list, m); mutex_unlock(&dev->struct_mutex); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Rob Clark97100.00%1100.00%
Total97100.00%1100.00%


static int mm_show(struct seq_file *m, void *arg) { struct drm_info_node *node = (struct drm_info_node *) m->private; struct drm_device *dev = node->minor->dev; struct drm_printer p = drm_seq_file_printer(m); drm_mm_print(&dev->vma_offset_manager->vm_addr_space_mm, &p); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Rob Clark4670.77%133.33%
Daniel Vetter1929.23%266.67%
Total65100.00%3100.00%

#ifdef CONFIG_DRM_FBDEV_EMULATION
static int fb_show(struct seq_file *m, void *arg) { struct drm_info_node *node = (struct drm_info_node *) m->private; struct drm_device *dev = node->minor->dev; struct omap_drm_private *priv = dev->dev_private; struct drm_framebuffer *fb; seq_printf(m, "fbcon "); omap_framebuffer_describe(priv->fbdev->fb, m); mutex_lock(&dev->mode_config.fb_lock); list_for_each_entry(fb, &dev->mode_config.fb_list, head) { if (fb == priv->fbdev->fb) continue; seq_printf(m, "user "); omap_framebuffer_describe(fb, m); } mutex_unlock(&dev->mode_config.fb_lock); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
Rob Clark11588.46%150.00%
Daniel Vetter1511.54%150.00%
Total130100.00%2100.00%

#endif /* list of debufs files that are applicable to all devices */ static struct drm_info_list omap_debugfs_list[] = { {"gem", gem_show, 0}, {"mm", mm_show, 0}, #ifdef CONFIG_DRM_FBDEV_EMULATION {"fb", fb_show, 0}, #endif }; /* list of debugfs files that are specific to devices with dmm/tiler */ static struct drm_info_list omap_dmm_debugfs_list[] = { {"tiler_map", tiler_map_show, 0}, };
int omap_debugfs_init(struct drm_minor *minor) { struct drm_device *dev = minor->dev; int ret; ret = drm_debugfs_create_files(omap_debugfs_list, ARRAY_SIZE(omap_debugfs_list), minor->debugfs_root, minor); if (ret) { dev_err(dev->dev, "could not install omap_debugfs_list\n"); return ret; } if (dmm_is_available()) ret = drm_debugfs_create_files(omap_dmm_debugfs_list, ARRAY_SIZE(omap_dmm_debugfs_list), minor->debugfs_root, minor); if (ret) { dev_err(dev->dev, "could not install omap_dmm_debugfs_list\n"); return ret; } return ret; }

Contributors

PersonTokensPropCommitsCommitProp
Rob Clark7169.61%133.33%
Andy Gross3130.39%266.67%
Total102100.00%3100.00%

#endif

Overall Contributors

PersonTokensPropCommitsCommitProp
Rob Clark36576.68%220.00%
Andy Gross5611.76%220.00%
Daniel Vetter347.14%330.00%
Laurent Pinchart183.78%220.00%
Arnd Bergmann30.63%110.00%
Total476100.00%10100.00%
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.