xref: /openbmc/linux/drivers/gpu/drm/radeon/radeon_pm.c (revision 7433874e31f7f2e6e942b12012790565731d0f4a)
1*7433874eSRafał Miłecki /*
2*7433874eSRafał Miłecki  * Permission is hereby granted, free of charge, to any person obtaining a
3*7433874eSRafał Miłecki  * copy of this software and associated documentation files (the "Software"),
4*7433874eSRafał Miłecki  * to deal in the Software without restriction, including without limitation
5*7433874eSRafał Miłecki  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
6*7433874eSRafał Miłecki  * and/or sell copies of the Software, and to permit persons to whom the
7*7433874eSRafał Miłecki  * Software is furnished to do so, subject to the following conditions:
8*7433874eSRafał Miłecki  *
9*7433874eSRafał Miłecki  * The above copyright notice and this permission notice shall be included in
10*7433874eSRafał Miłecki  * all copies or substantial portions of the Software.
11*7433874eSRafał Miłecki  *
12*7433874eSRafał Miłecki  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
13*7433874eSRafał Miłecki  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
14*7433874eSRafał Miłecki  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
15*7433874eSRafał Miłecki  * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
16*7433874eSRafał Miłecki  * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
17*7433874eSRafał Miłecki  * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
18*7433874eSRafał Miłecki  * OTHER DEALINGS IN THE SOFTWARE.
19*7433874eSRafał Miłecki  *
20*7433874eSRafał Miłecki  * Authors: Rafał Miłecki <zajec5@gmail.com>
21*7433874eSRafał Miłecki  */
22*7433874eSRafał Miłecki #include "drmP.h"
23*7433874eSRafał Miłecki #include "radeon.h"
24*7433874eSRafał Miłecki 
25*7433874eSRafał Miłecki int radeon_debugfs_pm_init(struct radeon_device *rdev);
26*7433874eSRafał Miłecki 
27*7433874eSRafał Miłecki int radeon_pm_init(struct radeon_device *rdev)
28*7433874eSRafał Miłecki {
29*7433874eSRafał Miłecki 	if (radeon_debugfs_pm_init(rdev)) {
30*7433874eSRafał Miłecki 		DRM_ERROR("Failed to register debugfs file for CP !\n");
31*7433874eSRafał Miłecki 	}
32*7433874eSRafał Miłecki 
33*7433874eSRafał Miłecki 	return 0;
34*7433874eSRafał Miłecki }
35*7433874eSRafał Miłecki 
36*7433874eSRafał Miłecki /*
37*7433874eSRafał Miłecki  * Debugfs info
38*7433874eSRafał Miłecki  */
39*7433874eSRafał Miłecki #if defined(CONFIG_DEBUG_FS)
40*7433874eSRafał Miłecki 
41*7433874eSRafał Miłecki static int radeon_debugfs_pm_info(struct seq_file *m, void *data)
42*7433874eSRafał Miłecki {
43*7433874eSRafał Miłecki 	struct drm_info_node *node = (struct drm_info_node *) m->private;
44*7433874eSRafał Miłecki 	struct drm_device *dev = node->minor->dev;
45*7433874eSRafał Miłecki 	struct radeon_device *rdev = dev->dev_private;
46*7433874eSRafał Miłecki 
47*7433874eSRafał Miłecki 	seq_printf(m, "engine clock: %u0 Hz\n", radeon_get_engine_clock(rdev));
48*7433874eSRafał Miłecki 	seq_printf(m, "memory clock: %u0 Hz\n", radeon_get_memory_clock(rdev));
49*7433874eSRafał Miłecki 
50*7433874eSRafał Miłecki 	return 0;
51*7433874eSRafał Miłecki }
52*7433874eSRafał Miłecki 
53*7433874eSRafał Miłecki static struct drm_info_list radeon_pm_info_list[] = {
54*7433874eSRafał Miłecki 	{"radeon_pm_info", radeon_debugfs_pm_info, 0, NULL},
55*7433874eSRafał Miłecki };
56*7433874eSRafał Miłecki #endif
57*7433874eSRafał Miłecki 
58*7433874eSRafał Miłecki int radeon_debugfs_pm_init(struct radeon_device *rdev)
59*7433874eSRafał Miłecki {
60*7433874eSRafał Miłecki #if defined(CONFIG_DEBUG_FS)
61*7433874eSRafał Miłecki 	return radeon_debugfs_add_files(rdev, radeon_pm_info_list, ARRAY_SIZE(radeon_pm_info_list));
62*7433874eSRafał Miłecki #else
63*7433874eSRafał Miłecki 	return 0;
64*7433874eSRafał Miłecki #endif
65*7433874eSRafał Miłecki }
66