| // SPDX-License-Identifier: MIT |
| /* |
| * Copyright © 2021 Intel Corporation |
| */ |
| |
| #include "xe_module.h" |
| |
| #include <linux/init.h> |
| #include <linux/module.h> |
| |
| #include <drm/drm_module.h> |
| |
| #include "xe_drv.h" |
| #include "xe_hw_fence.h" |
| #include "xe_pci.h" |
| #include "xe_pm.h" |
| #include "xe_observation.h" |
| #include "xe_sched_job.h" |
| |
| struct xe_modparam xe_modparam = { |
| .probe_display = true, |
| .guc_log_level = 5, |
| .force_probe = CONFIG_DRM_XE_FORCE_PROBE, |
| .wedged_mode = 1, |
| /* the rest are 0 by default */ |
| }; |
| |
| module_param_named_unsafe(force_execlist, xe_modparam.force_execlist, bool, 0444); |
| MODULE_PARM_DESC(force_execlist, "Force Execlist submission"); |
| |
| module_param_named(probe_display, xe_modparam.probe_display, bool, 0444); |
| MODULE_PARM_DESC(probe_display, "Probe display HW, otherwise it's left untouched (default: true)"); |
| |
| module_param_named(vram_bar_size, xe_modparam.force_vram_bar_size, uint, 0600); |
| MODULE_PARM_DESC(vram_bar_size, "Set the vram bar size(in MiB)"); |
| |
| module_param_named(guc_log_level, xe_modparam.guc_log_level, int, 0600); |
| MODULE_PARM_DESC(guc_log_level, "GuC firmware logging level (0=disable, 1..5=enable with verbosity min..max)"); |
| |
| module_param_named_unsafe(guc_firmware_path, xe_modparam.guc_firmware_path, charp, 0400); |
| MODULE_PARM_DESC(guc_firmware_path, |
| "GuC firmware path to use instead of the default one"); |
| |
| module_param_named_unsafe(huc_firmware_path, xe_modparam.huc_firmware_path, charp, 0400); |
| MODULE_PARM_DESC(huc_firmware_path, |
| "HuC firmware path to use instead of the default one - empty string disables"); |
| |
| module_param_named_unsafe(gsc_firmware_path, xe_modparam.gsc_firmware_path, charp, 0400); |
| MODULE_PARM_DESC(gsc_firmware_path, |
| "GSC firmware path to use instead of the default one - empty string disables"); |
| |
| module_param_named_unsafe(force_probe, xe_modparam.force_probe, charp, 0400); |
| MODULE_PARM_DESC(force_probe, |
| "Force probe options for specified devices. See CONFIG_DRM_XE_FORCE_PROBE for details."); |
| |
| #ifdef CONFIG_PCI_IOV |
| module_param_named(max_vfs, xe_modparam.max_vfs, uint, 0400); |
| MODULE_PARM_DESC(max_vfs, |
| "Limit number of Virtual Functions (VFs) that could be managed. " |
| "(0 = no VFs [default]; N = allow up to N VFs)"); |
| #endif |
| |
| module_param_named_unsafe(wedged_mode, xe_modparam.wedged_mode, int, 0600); |
| MODULE_PARM_DESC(wedged_mode, |
| "Module's default policy for the wedged mode - 0=never, 1=upon-critical-errors[default], 2=upon-any-hang"); |
| |
| static int xe_check_nomodeset(void) |
| { |
| if (drm_firmware_drivers_only()) |
| return -ENODEV; |
| |
| return 0; |
| } |
| |
| struct init_funcs { |
| int (*init)(void); |
| void (*exit)(void); |
| }; |
| |
| static void xe_dummy_exit(void) |
| { |
| } |
| |
| static const struct init_funcs init_funcs[] = { |
| { |
| .init = xe_check_nomodeset, |
| }, |
| { |
| .init = xe_hw_fence_module_init, |
| .exit = xe_hw_fence_module_exit, |
| }, |
| { |
| .init = xe_sched_job_module_init, |
| .exit = xe_sched_job_module_exit, |
| }, |
| { |
| .init = xe_register_pci_driver, |
| .exit = xe_unregister_pci_driver, |
| }, |
| { |
| .init = xe_observation_sysctl_register, |
| .exit = xe_observation_sysctl_unregister, |
| }, |
| { |
| .init = xe_pm_module_init, |
| .exit = xe_dummy_exit, |
| }, |
| }; |
| |
| static int __init xe_call_init_func(unsigned int i) |
| { |
| if (WARN_ON(i >= ARRAY_SIZE(init_funcs))) |
| return 0; |
| if (!init_funcs[i].init) |
| return 0; |
| |
| return init_funcs[i].init(); |
| } |
| |
| static void xe_call_exit_func(unsigned int i) |
| { |
| if (WARN_ON(i >= ARRAY_SIZE(init_funcs))) |
| return; |
| if (!init_funcs[i].exit) |
| return; |
| |
| init_funcs[i].exit(); |
| } |
| |
| static int __init xe_init(void) |
| { |
| int err, i; |
| |
| for (i = 0; i < ARRAY_SIZE(init_funcs); i++) { |
| err = xe_call_init_func(i); |
| if (err) { |
| while (i--) |
| xe_call_exit_func(i); |
| return err; |
| } |
| } |
| |
| return 0; |
| } |
| |
| static void __exit xe_exit(void) |
| { |
| int i; |
| |
| for (i = ARRAY_SIZE(init_funcs) - 1; i >= 0; i--) |
| xe_call_exit_func(i); |
| } |
| |
| module_init(xe_init); |
| module_exit(xe_exit); |
| |
| MODULE_AUTHOR("Intel Corporation"); |
| |
| MODULE_DESCRIPTION(DRIVER_DESC); |
| MODULE_LICENSE("GPL and additional rights"); |