[Intel-gfx] [PATCH v2 2/3] drm/i915: Extend I915_PARAMS_FOR_EACH with default member value

Jani Nikula jani.nikula at intel.com
Mon Sep 25 11:01:52 UTC 2017


On Mon, 25 Sep 2017, Michal Wajdeczko <michal.wajdeczko at intel.com> wrote:
> By combining default value into helper macro we can initialize
> modparams struct in the same automatic way as it was declared.
> This will initialize members in the same order as declared
> and additionally will disallow declaring new member without
> proper default value for it.
>
> v2: make MEMBER macro more robust (Joonas)
>
> Signed-off-by: Michal Wajdeczko <michal.wajdeczko at intel.com>
> Cc: Chris Wilson <chris at chris-wilson.co.uk>
> Cc: Jani Nikula <jani.nikula at intel.com>
> Cc: Joonas Lahtinen <joonas.lahtinen at linux.intel.com>
> Reviewed-by: Chris Wilson <chris at chris-wilson.co.uk>
> Acked-by: Jani Nikula <jani.nikula at intel.com>

FWIW my ack was for the entire series.

Jani.

> Reviewed-by: Joonas Lahtinen <joonas.lahtinen at linux.intel.com>
> ---
>  drivers/gpu/drm/i915/i915_debugfs.c   |  2 +-
>  drivers/gpu/drm/i915/i915_gpu_error.c |  6 +--
>  drivers/gpu/drm/i915/i915_params.c    | 42 ++----------------
>  drivers/gpu/drm/i915/i915_params.h    | 82 +++++++++++++++++------------------
>  4 files changed, 48 insertions(+), 84 deletions(-)
>
> diff --git a/drivers/gpu/drm/i915/i915_debugfs.c b/drivers/gpu/drm/i915/i915_debugfs.c
> index 847f8e8..b4a6ac6 100644
> --- a/drivers/gpu/drm/i915/i915_debugfs.c
> +++ b/drivers/gpu/drm/i915/i915_debugfs.c
> @@ -67,7 +67,7 @@ static int i915_capabilities(struct seq_file *m, void *data)
>  #undef PRINT_FLAG
>  
>  	kernel_param_lock(THIS_MODULE);
> -#define PRINT_PARAM(T, x) seq_print_param(m, #x, #T, &i915_modparams.x);
> +#define PRINT_PARAM(T, x, ...) seq_print_param(m, #x, #T, &i915_modparams.x);
>  	I915_PARAMS_FOR_EACH(PRINT_PARAM);
>  #undef PRINT_PARAM
>  	kernel_param_unlock(THIS_MODULE);
> diff --git a/drivers/gpu/drm/i915/i915_gpu_error.c b/drivers/gpu/drm/i915/i915_gpu_error.c
> index 12146d7..c14552a 100644
> --- a/drivers/gpu/drm/i915/i915_gpu_error.c
> +++ b/drivers/gpu/drm/i915/i915_gpu_error.c
> @@ -572,7 +572,7 @@ static __always_inline void err_print_param(struct drm_i915_error_state_buf *m,
>  static void err_print_params(struct drm_i915_error_state_buf *m,
>  			     const struct i915_params *p)
>  {
> -#define PRINT(T, x) err_print_param(m, #x, #T, &p->x);
> +#define PRINT(T, x, ...) err_print_param(m, #x, #T, &p->x);
>  	I915_PARAMS_FOR_EACH(PRINT);
>  #undef PRINT
>  }
> @@ -866,7 +866,7 @@ void __i915_gpu_state_free(struct kref *error_ref)
>  	kfree(error->overlay);
>  	kfree(error->display);
>  
> -#define FREE(T, x) free_param(#T, &error->params.x);
> +#define FREE(T, x, ...) free_param(#T, &error->params.x);
>  	I915_PARAMS_FOR_EACH(FREE);
>  #undef FREE
>  
> @@ -1704,7 +1704,7 @@ static int capture(void *data)
>  					   error->i915->gt.last_init_time));
>  
>  	error->params = i915_modparams;
> -#define DUP(T, x) dup_param(#T, &error->params.x);
> +#define DUP(T, x, ...) dup_param(#T, &error->params.x);
>  	I915_PARAMS_FOR_EACH(DUP);
>  #undef DUP
>  
> diff --git a/drivers/gpu/drm/i915/i915_params.c b/drivers/gpu/drm/i915/i915_params.c
> index ec65341..9dff323 100644
> --- a/drivers/gpu/drm/i915/i915_params.c
> +++ b/drivers/gpu/drm/i915/i915_params.c
> @@ -33,45 +33,9 @@
>  	MODULE_PARM_DESC(name, desc)
>  
>  struct i915_params i915_modparams __read_mostly = {
> -	.modeset = -1,
> -	.panel_ignore_lid = 1,
> -	.semaphores = -1,
> -	.lvds_channel_mode = 0,
> -	.panel_use_ssc = -1,
> -	.vbt_sdvo_panel_type = -1,
> -	.enable_rc6 = -1,
> -	.enable_dc = -1,
> -	.enable_fbc = -1,
> -	.enable_execlists = -1,
> -	.enable_hangcheck = true,
> -	.enable_ppgtt = -1,
> -	.enable_psr = -1,
> -	.alpha_support = IS_ENABLED(CONFIG_DRM_I915_ALPHA_SUPPORT),
> -	.disable_power_well = -1,
> -	.enable_ips = 1,
> -	.fastboot = 0,
> -	.prefault_disable = 0,
> -	.load_detect_test = 0,
> -	.force_reset_modeset_test = 0,
> -	.reset = 2,
> -	.error_capture = true,
> -	.invert_brightness = 0,
> -	.disable_display = 0,
> -	.enable_cmd_parser = true,
> -	.use_mmio_flip = 0,
> -	.mmio_debug = 0,
> -	.verbose_state_checks = 1,
> -	.nuclear_pageflip = 0,
> -	.edp_vswing = 0,
> -	.enable_guc_loading = 0,
> -	.enable_guc_submission = 0,
> -	.guc_log_level = -1,
> -	.guc_firmware_path = NULL,
> -	.huc_firmware_path = NULL,
> -	.enable_dp_mst = true,
> -	.inject_load_failure = 0,
> -	.enable_dpcd_backlight = false,
> -	.enable_gvt = false,
> +#define MEMBER(T, member, value) .member = (value),
> +	I915_PARAMS_FOR_EACH(MEMBER)
> +#undef MEMBER
>  };
>  
>  i915_param_named(modeset, int, 0400,
> diff --git a/drivers/gpu/drm/i915/i915_params.h b/drivers/gpu/drm/i915/i915_params.h
> index 0116bb9..da59939 100644
> --- a/drivers/gpu/drm/i915/i915_params.h
> +++ b/drivers/gpu/drm/i915/i915_params.h
> @@ -28,49 +28,49 @@
>  #include <linux/cache.h> /* for __read_mostly */
>  
>  #define I915_PARAMS_FOR_EACH(param) \
> -	param(char *, vbt_firmware) \
> -	param(int, modeset) \
> -	param(int, panel_ignore_lid) \
> -	param(int, semaphores) \
> -	param(int, lvds_channel_mode) \
> -	param(int, panel_use_ssc) \
> -	param(int, vbt_sdvo_panel_type) \
> -	param(int, enable_rc6) \
> -	param(int, enable_dc) \
> -	param(int, enable_fbc) \
> -	param(int, enable_ppgtt) \
> -	param(int, enable_execlists) \
> -	param(int, enable_psr) \
> -	param(int, disable_power_well) \
> -	param(int, enable_ips) \
> -	param(int, invert_brightness) \
> -	param(int, enable_guc_loading) \
> -	param(int, enable_guc_submission) \
> -	param(int, guc_log_level) \
> -	param(char *, guc_firmware_path) \
> -	param(char *, huc_firmware_path) \
> -	param(int, use_mmio_flip) \
> -	param(int, mmio_debug) \
> -	param(int, edp_vswing) \
> -	param(int, reset) \
> -	param(unsigned int, inject_load_failure) \
> +	param(char *, vbt_firmware, NULL) \
> +	param(int, modeset, -1) \
> +	param(int, panel_ignore_lid, 1) \
> +	param(int, semaphores, -1) \
> +	param(int, lvds_channel_mode, 0) \
> +	param(int, panel_use_ssc, -1) \
> +	param(int, vbt_sdvo_panel_type, -1) \
> +	param(int, enable_rc6, -1) \
> +	param(int, enable_dc, -1) \
> +	param(int, enable_fbc, -1) \
> +	param(int, enable_ppgtt, -1) \
> +	param(int, enable_execlists, -1) \
> +	param(int, enable_psr, -1) \
> +	param(int, disable_power_well, -1) \
> +	param(int, enable_ips, 1) \
> +	param(int, invert_brightness, 0) \
> +	param(int, enable_guc_loading, 0) \
> +	param(int, enable_guc_submission, 0) \
> +	param(int, guc_log_level, -1) \
> +	param(char *, guc_firmware_path, NULL) \
> +	param(char *, huc_firmware_path, NULL) \
> +	param(int, use_mmio_flip, 0) \
> +	param(int, mmio_debug, 0) \
> +	param(int, edp_vswing, 0) \
> +	param(int, reset, 2) \
> +	param(unsigned int, inject_load_failure, 0) \
>  	/* leave bools at the end to not create holes */ \
> -	param(bool, alpha_support) \
> -	param(bool, enable_cmd_parser) \
> -	param(bool, enable_hangcheck) \
> -	param(bool, fastboot) \
> -	param(bool, prefault_disable) \
> -	param(bool, load_detect_test) \
> -	param(bool, force_reset_modeset_test) \
> -	param(bool, error_capture) \
> -	param(bool, disable_display) \
> -	param(bool, verbose_state_checks) \
> -	param(bool, nuclear_pageflip) \
> -	param(bool, enable_dp_mst) \
> -	param(bool, enable_dpcd_backlight) \
> -	param(bool, enable_gvt)
> +	param(bool, alpha_support, IS_ENABLED(CONFIG_DRM_I915_ALPHA_SUPPORT)) \
> +	param(bool, enable_cmd_parser, true) \
> +	param(bool, enable_hangcheck, true) \
> +	param(bool, fastboot, 0) \
> +	param(bool, prefault_disable, 0) \
> +	param(bool, load_detect_test, 0) \
> +	param(bool, force_reset_modeset_test, 0) \
> +	param(bool, error_capture, true) \
> +	param(bool, disable_display, 0) \
> +	param(bool, verbose_state_checks, 1) \
> +	param(bool, nuclear_pageflip, 0) \
> +	param(bool, enable_dp_mst, true) \
> +	param(bool, enable_dpcd_backlight, false) \
> +	param(bool, enable_gvt, false)
>  
> -#define MEMBER(T, member) T member;
> +#define MEMBER(T, member, ...) T member;
>  struct i915_params {
>  	I915_PARAMS_FOR_EACH(MEMBER);
>  };

-- 
Jani Nikula, Intel Open Source Technology Center


More information about the Intel-gfx mailing list