2019-06-01 10:08:42 +02:00
// SPDX-License-Identifier: GPL-2.0-only
2012-10-04 15:32:52 +02:00
/*
* generic videomode helper
*
* Copyright ( c ) 2012 Steffen Trumtrar < s . trumtrar @ pengutronix . de > , Pengutronix
*/
# include <linux/errno.h>
# include <linux/export.h>
# include <linux/of.h>
# include <video/display_timing.h>
# include <video/of_display_timing.h>
# include <video/of_videomode.h>
# include <video/videomode.h>
/**
* of_get_videomode - get the videomode # < index > from devicetree
* @ np - devicenode with the display_timings
* @ vm - set to return value
* @ index - index into list of display_timings
* ( Set this to OF_USE_NATIVE_MODE to use whatever mode is
* specified as native mode in the DT . )
*
* DESCRIPTION :
* Get a list of all display timings and put the one
* specified by index into * vm . This function should only be used , if
* only one videomode is to be retrieved . A driver that needs to work
* with multiple / all videomodes should work with
* of_get_display_timings instead .
* */
int of_get_videomode ( struct device_node * np , struct videomode * vm ,
int index )
{
struct display_timings * disp ;
int ret ;
disp = of_get_display_timings ( np ) ;
if ( ! disp ) {
2017-08-07 17:22:13 +02:00
pr_err ( " %pOF: no timings specified \n " , np ) ;
2012-10-04 15:32:52 +02:00
return - EINVAL ;
}
if ( index = = OF_USE_NATIVE_MODE )
index = disp - > native_mode ;
2013-03-21 14:20:12 +02:00
ret = videomode_from_timings ( disp , vm , index ) ;
2012-10-04 15:32:52 +02:00
display_timings_release ( disp ) ;
2015-07-11 19:46:11 +02:00
return ret ;
2012-10-04 15:32:52 +02:00
}
EXPORT_SYMBOL_GPL ( of_get_videomode ) ;