2017-03-22 23:53:36 +03:00
/*
* Internal Header for the Direct Rendering Manager
*
* Copyright 1999 Precision Insight , Inc . , Cedar Park , Texas .
* Copyright 2000 VA Linux Systems , Inc . , Sunnyvale , California .
* Copyright ( c ) 2009 - 2010 , Code Aurora Forum .
* All rights reserved .
*
* Author : Rickard E . ( Rik ) Faith < faith @ valinux . com >
* Author : Gareth Hughes < gareth @ valinux . com >
*
* Permission is hereby granted , free of charge , to any person obtaining a
* copy of this software and associated documentation files ( the " Software " ) ,
* to deal in the Software without restriction , including without limitation
* the rights to use , copy , modify , merge , publish , distribute , sublicense ,
* and / or sell copies of the Software , and to permit persons to whom the
* Software is furnished to do so , subject to the following conditions :
*
* The above copyright notice and this permission notice ( including the next
* paragraph ) shall be included in all copies or substantial portions of the
* Software .
*
* THE SOFTWARE IS PROVIDED " AS IS " , WITHOUT WARRANTY OF ANY KIND , EXPRESS OR
* IMPLIED , INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY ,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT . IN NO EVENT SHALL
* VA LINUX SYSTEMS AND / OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM , DAMAGES OR
* OTHER LIABILITY , WHETHER IN AN ACTION OF CONTRACT , TORT OR OTHERWISE ,
* ARISING FROM , OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
* OTHER DEALINGS IN THE SOFTWARE .
*/
# ifndef _DRM_DEBUGFS_H_
# define _DRM_DEBUGFS_H_
2019-06-08 11:02:36 +03:00
# include <linux/types.h>
# include <linux/seq_file.h>
2023-07-20 03:14:23 +03:00
2023-09-20 17:42:34 +03:00
# include <drm/drm_gpuvm.h>
2023-07-20 03:14:23 +03:00
/**
* DRM_DEBUGFS_GPUVA_INFO - & drm_info_list entry to dump a GPU VA space
* @ show : the & drm_info_list ' s show callback
* @ data : driver private data
*
* Drivers should use this macro to define a & drm_info_list entry to provide a
* debugfs file for dumping the GPU VA space regions and mappings .
*
* For each DRM GPU VA space drivers should call drm_debugfs_gpuva_info ( ) from
* their @ show callback .
*/
# define DRM_DEBUGFS_GPUVA_INFO(show, data) {"gpuvas", show, DRIVER_GEM_GPUVA, data}
2017-03-22 23:53:36 +03:00
/**
2017-03-22 23:54:01 +03:00
* struct drm_info_list - debugfs info list entry
*
* This structure represents a debugfs file to be created by the drm
* core .
2017-03-22 23:53:36 +03:00
*/
struct drm_info_list {
2017-03-22 23:54:01 +03:00
/** @name: file name */
const char * name ;
/**
* @ show :
*
* Show callback . & seq_file - > private will be set to the & struct
* drm_info_node corresponding to the instance of this info on a given
* & struct drm_minor .
*/
int ( * show ) ( struct seq_file * , void * ) ;
/** @driver_features: Required driver features for this entry */
u32 driver_features ;
/** @data: Driver-private data, should not be device-specific. */
2017-03-22 23:53:36 +03:00
void * data ;
} ;
/**
2017-03-22 23:54:01 +03:00
* struct drm_info_node - Per - minor debugfs node structure
*
* This structure represents a debugfs file , as an instantiation of a & struct
* drm_info_list on a & struct drm_minor .
*
* FIXME :
*
* No it doesn ' t make a hole lot of sense that we duplicate debugfs entries for
* both the render and the primary nodes , but that ' s how this has organically
* grown . It should probably be fixed , with a compatibility link , if needed .
2017-03-22 23:53:36 +03:00
*/
struct drm_info_node {
2017-03-22 23:54:01 +03:00
/** @minor: &struct drm_minor for this node. */
2017-03-22 23:53:36 +03:00
struct drm_minor * minor ;
2017-03-22 23:54:01 +03:00
/** @info_ent: template for this node. */
2017-03-22 23:53:36 +03:00
const struct drm_info_list * info_ent ;
2017-03-22 23:54:01 +03:00
/* private: */
struct list_head list ;
2017-03-22 23:53:36 +03:00
struct dentry * dent ;
} ;
2022-12-19 15:06:15 +03:00
/**
* struct drm_debugfs_info - debugfs info list entry
*
* This structure represents a debugfs file to be created by the drm
* core .
*/
struct drm_debugfs_info {
2023-01-05 22:30:39 +03:00
/** @name: File name */
2022-12-19 15:06:15 +03:00
const char * name ;
2023-01-05 22:30:39 +03:00
/**
* @ show :
*
* Show callback . & seq_file - > private will be set to the & struct
* drm_debugfs_entry corresponding to the instance of this info
* on a given & struct drm_device .
*/
2022-12-19 15:06:15 +03:00
int ( * show ) ( struct seq_file * , void * ) ;
2023-01-05 22:30:39 +03:00
/** @driver_features: Required driver features for this entry. */
2022-12-19 15:06:15 +03:00
u32 driver_features ;
2023-01-05 22:30:39 +03:00
/** @data: Driver-private data, should not be device-specific. */
2022-12-19 15:06:15 +03:00
void * data ;
} ;
/**
* struct drm_debugfs_entry - Per - device debugfs node structure
*
* This structure represents a debugfs file , as an instantiation of a & struct
* drm_debugfs_info on a & struct drm_device .
*/
struct drm_debugfs_entry {
2023-01-05 22:30:39 +03:00
/** @dev: &struct drm_device for this node. */
2022-12-19 15:06:15 +03:00
struct drm_device * dev ;
2023-01-05 22:30:39 +03:00
/** @file: Template for this node. */
2022-12-19 15:06:15 +03:00
struct drm_debugfs_info file ;
2023-01-05 22:30:39 +03:00
/** @list: Linked list of all device nodes. */
2022-12-19 15:06:15 +03:00
struct list_head list ;
} ;
2017-03-22 23:53:36 +03:00
# if defined(CONFIG_DEBUG_FS)
2020-03-10 16:31:20 +03:00
void drm_debugfs_create_files ( const struct drm_info_list * files ,
int count , struct dentry * root ,
struct drm_minor * minor ) ;
2023-08-29 14:01:15 +03:00
int drm_debugfs_remove_files ( const struct drm_info_list * files , int count ,
struct dentry * root , struct drm_minor * minor ) ;
2022-12-19 15:06:15 +03:00
void drm_debugfs_add_file ( struct drm_device * dev , const char * name ,
int ( * show ) ( struct seq_file * , void * ) , void * data ) ;
void drm_debugfs_add_files ( struct drm_device * dev ,
const struct drm_debugfs_info * files , int count ) ;
2023-07-20 03:14:23 +03:00
int drm_debugfs_gpuva_info ( struct seq_file * m ,
2023-09-20 17:42:34 +03:00
struct drm_gpuvm * gpuvm ) ;
2017-03-22 23:53:36 +03:00
# else
2020-03-10 16:31:20 +03:00
static inline void drm_debugfs_create_files ( const struct drm_info_list * files ,
int count , struct dentry * root ,
struct drm_minor * minor )
{ }
2017-03-22 23:53:36 +03:00
static inline int drm_debugfs_remove_files ( const struct drm_info_list * files ,
2023-09-14 02:30:24 +03:00
int count , struct dentry * root ,
struct drm_minor * minor )
2017-03-22 23:53:36 +03:00
{
return 0 ;
}
2022-12-19 15:06:15 +03:00
static inline void drm_debugfs_add_file ( struct drm_device * dev , const char * name ,
int ( * show ) ( struct seq_file * , void * ) ,
void * data )
{ }
static inline void drm_debugfs_add_files ( struct drm_device * dev ,
const struct drm_debugfs_info * files ,
int count )
{ }
2023-07-20 03:14:23 +03:00
static inline int drm_debugfs_gpuva_info ( struct seq_file * m ,
2023-09-20 17:42:34 +03:00
struct drm_gpuvm * gpuvm )
2023-07-20 03:14:23 +03:00
{
return 0 ;
}
2017-03-22 23:53:36 +03:00
# endif
# endif /* _DRM_DEBUGFS_H_ */