2015-12-18 13:08:15 +02:00
/*
* Copyright © 2015 Intel Corporation
*
* 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
* THE AUTHORS OR COPYRIGHT HOLDERS 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 _I915_PARAMS_H_
# define _I915_PARAMS_H_
2017-12-06 13:53:15 +00:00
# include <linux/bitops.h>
2015-12-18 13:08:15 +02:00
# include <linux/cache.h> /* for __read_mostly */
2017-12-19 11:43:46 +00:00
struct drm_printer ;
2017-12-06 13:53:15 +00:00
# define ENABLE_GUC_SUBMISSION BIT(0)
# define ENABLE_GUC_LOAD_HUC BIT(1)
2021-01-13 14:07:24 -08:00
# define ENABLE_GUC_MASK GENMASK(1, 0)
2017-12-06 13:53:15 +00:00
2018-12-27 16:33:42 +02:00
/*
* Invoke param , a function - like macro , for each i915 param , with arguments :
*
2019-12-05 17:43:40 +02:00
* param ( type , name , value , mode )
2018-12-27 16:33:42 +02:00
*
2019-12-05 17:43:40 +02:00
* type : parameter type , one of { bool , int , unsigned int , unsigned long , char * }
2018-12-27 16:33:42 +02:00
* name : name of the parameter
* value : initial / default value of the parameter
2019-12-05 17:43:40 +02:00
* mode : debugfs file permissions , one of { 0400 , 0600 , 0 } , use 0 to not create
* debugfs file
2018-12-27 16:33:42 +02:00
*/
2017-09-25 10:50:06 +00:00
# define I915_PARAMS_FOR_EACH(param) \
2019-12-05 17:43:40 +02:00
param ( char * , vbt_firmware , NULL , 0400 ) \
param ( int , modeset , - 1 , 0400 ) \
param ( int , lvds_channel_mode , 0 , 0400 ) \
param ( int , panel_use_ssc , - 1 , 0600 ) \
param ( int , vbt_sdvo_panel_type , - 1 , 0400 ) \
param ( int , enable_dc , - 1 , 0400 ) \
param ( int , enable_fbc , - 1 , 0600 ) \
param ( int , enable_psr , - 1 , 0600 ) \
2021-02-04 07:33:57 -08:00
param ( bool , psr_safest_params , false , 0400 ) \
2021-09-29 17:14:08 -07:00
param ( bool , enable_psr2_sel_fetch , true , 0400 ) \
2019-12-05 17:43:40 +02:00
param ( int , disable_power_well , - 1 , 0400 ) \
param ( int , enable_ips , 1 , 0600 ) \
param ( int , invert_brightness , 0 , 0600 ) \
2021-06-03 09:48:12 -07:00
param ( int , enable_guc , - 1 , 0400 ) \
2019-12-05 17:43:40 +02:00
param ( int , guc_log_level , - 1 , 0400 ) \
param ( char * , guc_firmware_path , NULL , 0400 ) \
param ( char * , huc_firmware_path , NULL , 0400 ) \
param ( char * , dmc_firmware_path , NULL , 0400 ) \
param ( int , mmio_debug , - IS_ENABLED ( CONFIG_DRM_I915_DEBUG_MMIO ) , 0600 ) \
param ( int , edp_vswing , 0 , 0400 ) \
2020-02-05 12:37:57 +00:00
param ( unsigned int , reset , 3 , 0600 ) \
2020-06-02 00:55:08 +03:00
param ( unsigned int , inject_probe_failure , 0 , 0 ) \
2019-12-05 17:43:40 +02:00
param ( int , fastboot , - 1 , 0600 ) \
2020-01-16 16:16:12 -05:00
param ( int , enable_dpcd_backlight , - 1 , 0600 ) \
2019-12-05 17:43:40 +02:00
param ( char * , force_probe , CONFIG_DRM_I915_FORCE_PROBE , 0400 ) \
2021-05-26 15:19:46 +01:00
param ( unsigned long , fake_lmem_start , 0 , IS_ENABLED ( CONFIG_DRM_I915_UNSTABLE_FAKE_LMEM ) ? 0400 : 0 ) \
param ( unsigned int , request_timeout_ms , CONFIG_DRM_I915_REQUEST_TIMEOUT , CONFIG_DRM_I915_REQUEST_TIMEOUT ? 0600 : 0 ) \
2017-02-06 21:36:05 +00:00
/* leave bools at the end to not create holes */ \
2019-12-05 17:43:40 +02:00
param ( bool , enable_hangcheck , true , 0600 ) \
param ( bool , load_detect_test , false , 0600 ) \
param ( bool , force_reset_modeset_test , false , 0600 ) \
2021-05-26 15:19:46 +01:00
param ( bool , error_capture , true , IS_ENABLED ( CONFIG_DRM_I915_CAPTURE_ERROR ) ? 0600 : 0 ) \
2019-12-05 17:43:40 +02:00
param ( bool , disable_display , false , 0400 ) \
param ( bool , verbose_state_checks , true , 0 ) \
param ( bool , nuclear_pageflip , false , 0400 ) \
param ( bool , enable_dp_mst , true , 0600 ) \
2021-05-26 15:19:46 +01:00
param ( bool , enable_gvt , false , IS_ENABLED ( CONFIG_DRM_I915_GVT ) ? 0400 : 0 )
2017-02-06 21:36:05 +00:00
2017-09-25 10:50:07 +00:00
# define MEMBER(T, member, ...) T member;
2015-12-18 13:08:15 +02:00
struct i915_params {
2017-02-06 21:36:05 +00:00
I915_PARAMS_FOR_EACH ( MEMBER ) ;
2015-12-18 13:08:15 +02:00
} ;
2017-02-06 21:36:05 +00:00
# undef MEMBER
2015-12-18 13:08:15 +02:00
2017-09-19 19:38:44 +00:00
extern struct i915_params i915_modparams __read_mostly ;
2015-12-18 13:08:15 +02:00
2017-12-19 11:43:46 +00:00
void i915_params_dump ( const struct i915_params * params , struct drm_printer * p ) ;
2018-12-27 16:33:37 +02:00
void i915_params_copy ( struct i915_params * dest , const struct i915_params * src ) ;
2018-12-27 16:33:38 +02:00
void i915_params_free ( struct i915_params * params ) ;
2017-12-19 11:43:46 +00:00
2015-12-18 13:08:15 +02:00
# endif