mirror of
https://github.com/NVIDIA/open-gpu-kernel-modules.git
synced 2025-01-08 07:46:06 +01:00
259 lines
11 KiB
Plaintext
259 lines
11 KiB
Plaintext
|
###########################################################################
|
||
|
# Kbuild fragment for nvidia.ko
|
||
|
###########################################################################
|
||
|
|
||
|
#
|
||
|
# Define NVIDIA_{SOURCES,OBJECTS}
|
||
|
#
|
||
|
|
||
|
include $(src)/nvidia/nvidia-sources.Kbuild
|
||
|
NVIDIA_OBJECTS = $(patsubst %.c,%.o,$(NVIDIA_SOURCES))
|
||
|
|
||
|
obj-m += nvidia.o
|
||
|
nvidia-y := $(NVIDIA_OBJECTS)
|
||
|
|
||
|
NVIDIA_KO = nvidia/nvidia.ko
|
||
|
|
||
|
|
||
|
#
|
||
|
# nv-kernel.o_binary is the core binary component of nvidia.ko, shared
|
||
|
# across all UNIX platforms. Create a symlink, "nv-kernel.o" that
|
||
|
# points to nv-kernel.o_binary, and add nv-kernel.o to the list of
|
||
|
# objects to link into nvidia.ko.
|
||
|
#
|
||
|
# Note that:
|
||
|
# - The kbuild "clean" rule will delete all objects in nvidia-y (which
|
||
|
# is why we use a symlink instead of just adding nv-kernel.o_binary
|
||
|
# to nvidia-y).
|
||
|
# - kbuild normally uses the naming convention of ".o_shipped" for
|
||
|
# binary files. That is not used here, because the kbuild rule to
|
||
|
# create the "normal" object file from ".o_shipped" does a copy, not
|
||
|
# a symlink. This file is quite large, so a symlink is preferred.
|
||
|
# - The file added to nvidia-y should be relative to gmake's cwd.
|
||
|
# But, the target for the symlink rule should be prepended with $(obj).
|
||
|
# - The "symlink" command is called using kbuild's if_changed macro to
|
||
|
# generate an .nv-kernel.o.cmd file which can be used on subsequent
|
||
|
# runs to determine if the command line to create the symlink changed
|
||
|
# and needs to be re-executed.
|
||
|
#
|
||
|
|
||
|
NVIDIA_BINARY_OBJECT := $(src)/nvidia/nv-kernel.o_binary
|
||
|
NVIDIA_BINARY_OBJECT_O := nvidia/nv-kernel.o
|
||
|
|
||
|
quiet_cmd_symlink = SYMLINK $@
|
||
|
cmd_symlink = ln -sf $< $@
|
||
|
|
||
|
targets += $(NVIDIA_BINARY_OBJECT_O)
|
||
|
|
||
|
$(obj)/$(NVIDIA_BINARY_OBJECT_O): $(NVIDIA_BINARY_OBJECT) FORCE
|
||
|
$(call if_changed,symlink)
|
||
|
|
||
|
nvidia-y += $(NVIDIA_BINARY_OBJECT_O)
|
||
|
|
||
|
|
||
|
#
|
||
|
# Define nvidia.ko-specific CFLAGS.
|
||
|
#
|
||
|
|
||
|
NVIDIA_CFLAGS += -I$(src)/nvidia
|
||
|
NVIDIA_CFLAGS += -DNVIDIA_UNDEF_LEGACY_BIT_MACROS
|
||
|
|
||
|
ifeq ($(NV_BUILD_TYPE),release)
|
||
|
NVIDIA_CFLAGS += -UDEBUG -U_DEBUG -DNDEBUG
|
||
|
endif
|
||
|
|
||
|
ifeq ($(NV_BUILD_TYPE),develop)
|
||
|
NVIDIA_CFLAGS += -UDEBUG -U_DEBUG -DNDEBUG -DNV_MEM_LOGGER
|
||
|
endif
|
||
|
|
||
|
ifeq ($(NV_BUILD_TYPE),debug)
|
||
|
NVIDIA_CFLAGS += -DDEBUG -D_DEBUG -UNDEBUG -DNV_MEM_LOGGER
|
||
|
endif
|
||
|
|
||
|
$(call ASSIGN_PER_OBJ_CFLAGS, $(NVIDIA_OBJECTS), $(NVIDIA_CFLAGS))
|
||
|
|
||
|
|
||
|
#
|
||
|
# nv-procfs.c requires nv-compiler.h
|
||
|
#
|
||
|
|
||
|
NV_COMPILER_VERSION_HEADER = $(obj)/nv_compiler.h
|
||
|
|
||
|
$(NV_COMPILER_VERSION_HEADER):
|
||
|
@echo \#define NV_COMPILER \"`$(CC) -v 2>&1 | tail -n 1`\" > $@
|
||
|
|
||
|
$(obj)/nvidia/nv-procfs.o: $(NV_COMPILER_VERSION_HEADER)
|
||
|
|
||
|
clean-files += $(NV_COMPILER_VERSION_HEADER)
|
||
|
|
||
|
|
||
|
#
|
||
|
# Build nv-interface.o from the kernel interface layer objects, suitable
|
||
|
# for further processing by the top-level makefile to produce a precompiled
|
||
|
# kernel interface file.
|
||
|
#
|
||
|
|
||
|
NVIDIA_INTERFACE := nvidia/nv-interface.o
|
||
|
|
||
|
# Linux kernel v5.12 and later looks at "always-y", Linux kernel versions
|
||
|
# before v5.6 looks at "always"; kernel versions between v5.12 and v5.6
|
||
|
# look at both.
|
||
|
|
||
|
always += $(NVIDIA_INTERFACE)
|
||
|
always-y += $(NVIDIA_INTERFACE)
|
||
|
|
||
|
$(obj)/$(NVIDIA_INTERFACE): $(addprefix $(obj)/,$(NVIDIA_OBJECTS))
|
||
|
$(LD) -r -o $@ $^
|
||
|
|
||
|
|
||
|
#
|
||
|
# Register the conftests needed by nvidia.ko
|
||
|
#
|
||
|
|
||
|
NV_OBJECTS_DEPEND_ON_CONFTEST += $(NVIDIA_OBJECTS)
|
||
|
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += hash__remap_4k_pfn
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += set_pages_uc
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += list_is_first
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += set_memory_uc
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += set_memory_array_uc
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += set_pages_array_uc
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += ioremap_cache
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += ioremap_wc
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += sg_alloc_table
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += pci_get_domain_bus_and_slot
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += get_num_physpages
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += efi_enabled
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += pde_data
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += proc_remove
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += pm_vt_switch_required
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += xen_ioemu_inject_msi
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += phys_to_dma
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += get_dma_ops
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += dma_attr_macros
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += dma_map_page_attrs
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += write_cr4
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += of_get_property
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += of_find_node_by_phandle
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += of_node_to_nid
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += pnv_pci_get_npu_dev
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += of_get_ibm_chip_id
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += pci_bus_address
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += pci_stop_and_remove_bus_device
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += pci_remove_bus_device
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += register_cpu_notifier
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += cpuhp_setup_state
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += dma_map_resource
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += get_backlight_device_by_name
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += timer_setup
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += pci_enable_msix_range
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += kernel_read_has_pointer_pos_arg
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += kernel_write
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += kthread_create_on_node
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += of_find_matching_node
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += dev_is_pci
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += dma_direct_map_resource
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += tegra_get_platform
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += tegra_bpmp_send_receive
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += flush_cache_all
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += vmf_insert_pfn
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += jiffies_to_timespec
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += ktime_get_raw_ts64
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += ktime_get_real_ts64
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += full_name_hash
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += hlist_for_each_entry
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += pci_enable_atomic_ops_to_root
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += vga_tryget
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += pgprot_decrypted
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += cc_mkdec
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += iterate_fd
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += seq_read_iter
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += sg_page_iter_page
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += unsafe_follow_pfn
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += drm_gem_object_get
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += drm_gem_object_put_unlocked
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += set_close_on_exec
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += add_memory_driver_managed
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += device_property_read_u64
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += devm_of_platform_populate
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += of_dma_configure
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += of_property_count_elems_of_size
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += of_property_read_variable_u8_array
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += i2c_new_client_device
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += i2c_unregister_device
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += of_get_named_gpio
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += devm_gpio_request_one
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += gpio_direction_input
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += gpio_direction_output
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += gpio_get_value
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += gpio_set_value
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += gpio_to_irq
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += icc_get
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += icc_put
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += icc_set_bw
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += dma_buf_export_args
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += dma_buf_ops_has_kmap
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += dma_buf_ops_has_kmap_atomic
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += dma_buf_ops_has_map
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += dma_buf_ops_has_map_atomic
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += dma_buf_has_dynamic_attachment
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += dma_buf_attachment_has_peer2peer
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += dma_set_mask_and_coherent
|
||
|
NV_CONFTEST_FUNCTION_COMPILE_TESTS += acpi_bus_get_device
|
||
|
|
||
|
NV_CONFTEST_SYMBOL_COMPILE_TESTS += is_export_symbol_gpl_of_node_to_nid
|
||
|
NV_CONFTEST_SYMBOL_COMPILE_TESTS += is_export_symbol_gpl_sme_active
|
||
|
NV_CONFTEST_SYMBOL_COMPILE_TESTS += is_export_symbol_present_swiotlb_map_sg_attrs
|
||
|
NV_CONFTEST_SYMBOL_COMPILE_TESTS += is_export_symbol_present_swiotlb_dma_ops
|
||
|
NV_CONFTEST_SYMBOL_COMPILE_TESTS += is_export_symbol_present___close_fd
|
||
|
NV_CONFTEST_SYMBOL_COMPILE_TESTS += is_export_symbol_present_close_fd
|
||
|
NV_CONFTEST_SYMBOL_COMPILE_TESTS += is_export_symbol_present_get_unused_fd
|
||
|
NV_CONFTEST_SYMBOL_COMPILE_TESTS += is_export_symbol_present_get_unused_fd_flags
|
||
|
NV_CONFTEST_SYMBOL_COMPILE_TESTS += is_export_symbol_present_nvhost_get_default_device
|
||
|
NV_CONFTEST_SYMBOL_COMPILE_TESTS += is_export_symbol_present_nvhost_syncpt_unit_interface_get_byte_offset
|
||
|
NV_CONFTEST_SYMBOL_COMPILE_TESTS += is_export_symbol_present_nvhost_syncpt_unit_interface_get_aperture
|
||
|
NV_CONFTEST_SYMBOL_COMPILE_TESTS += is_export_symbol_present_tegra_dce_register_ipc_client
|
||
|
NV_CONFTEST_SYMBOL_COMPILE_TESTS += is_export_symbol_present_tegra_dce_unregister_ipc_client
|
||
|
NV_CONFTEST_SYMBOL_COMPILE_TESTS += is_export_symbol_present_tegra_dce_client_ipc_send_recv
|
||
|
NV_CONFTEST_SYMBOL_COMPILE_TESTS += is_export_symbol_present_dram_clk_to_mc_clk
|
||
|
NV_CONFTEST_SYMBOL_COMPILE_TESTS += is_export_symbol_present_get_dram_num_channels
|
||
|
NV_CONFTEST_SYMBOL_COMPILE_TESTS += is_export_symbol_present_tegra_dram_types
|
||
|
NV_CONFTEST_SYMBOL_COMPILE_TESTS += is_export_symbol_present_pxm_to_node
|
||
|
|
||
|
NV_CONFTEST_TYPE_COMPILE_TESTS += file_operations
|
||
|
NV_CONFTEST_TYPE_COMPILE_TESTS += kuid_t
|
||
|
NV_CONFTEST_TYPE_COMPILE_TESTS += dma_ops
|
||
|
NV_CONFTEST_TYPE_COMPILE_TESTS += swiotlb_dma_ops
|
||
|
NV_CONFTEST_TYPE_COMPILE_TESTS += noncoherent_swiotlb_dma_ops
|
||
|
NV_CONFTEST_TYPE_COMPILE_TESTS += vm_fault_has_address
|
||
|
NV_CONFTEST_TYPE_COMPILE_TESTS += vm_insert_pfn_prot
|
||
|
NV_CONFTEST_TYPE_COMPILE_TESTS += vmf_insert_pfn_prot
|
||
|
NV_CONFTEST_TYPE_COMPILE_TESTS += address_space_init_once
|
||
|
NV_CONFTEST_TYPE_COMPILE_TESTS += vm_ops_fault_removed_vma_arg
|
||
|
NV_CONFTEST_TYPE_COMPILE_TESTS += vmbus_channel_has_ringbuffer_page
|
||
|
NV_CONFTEST_TYPE_COMPILE_TESTS += device_driver_of_match_table
|
||
|
NV_CONFTEST_TYPE_COMPILE_TESTS += device_of_node
|
||
|
NV_CONFTEST_TYPE_COMPILE_TESTS += node_states_n_memory
|
||
|
NV_CONFTEST_TYPE_COMPILE_TESTS += kmem_cache_has_kobj_remove_work
|
||
|
NV_CONFTEST_TYPE_COMPILE_TESTS += sysfs_slab_unlink
|
||
|
NV_CONFTEST_TYPE_COMPILE_TESTS += proc_ops
|
||
|
NV_CONFTEST_TYPE_COMPILE_TESTS += timespec64
|
||
|
NV_CONFTEST_TYPE_COMPILE_TESTS += vmalloc_has_pgprot_t_arg
|
||
|
NV_CONFTEST_TYPE_COMPILE_TESTS += mm_has_mmap_lock
|
||
|
NV_CONFTEST_TYPE_COMPILE_TESTS += pci_channel_state
|
||
|
NV_CONFTEST_TYPE_COMPILE_TESTS += pci_dev_has_ats_enabled
|
||
|
NV_CONFTEST_TYPE_COMPILE_TESTS += mt_device_gre
|
||
|
NV_CONFTEST_TYPE_COMPILE_TESTS += remove_memory_has_nid_arg
|
||
|
NV_CONFTEST_TYPE_COMPILE_TESTS += add_memory_driver_managed_has_mhp_flags_arg
|
||
|
|
||
|
NV_CONFTEST_GENERIC_COMPILE_TESTS += dom0_kernel_present
|
||
|
NV_CONFTEST_GENERIC_COMPILE_TESTS += nvidia_vgpu_kvm_build
|
||
|
NV_CONFTEST_GENERIC_COMPILE_TESTS += nvidia_grid_build
|
||
|
NV_CONFTEST_GENERIC_COMPILE_TESTS += nvidia_grid_csp_build
|
||
|
NV_CONFTEST_GENERIC_COMPILE_TESTS += get_user_pages
|
||
|
NV_CONFTEST_GENERIC_COMPILE_TESTS += get_user_pages_remote
|
||
|
NV_CONFTEST_GENERIC_COMPILE_TESTS += pm_runtime_available
|
||
|
NV_CONFTEST_GENERIC_COMPILE_TESTS += vm_fault_t
|
||
|
NV_CONFTEST_GENERIC_COMPILE_TESTS += pci_class_multimedia_hd_audio
|
||
|
NV_CONFTEST_GENERIC_COMPILE_TESTS += drm_available
|