diff options
Diffstat (limited to 'drivers/media/video/samsung/mali/Makefile')
-rw-r--r-- | drivers/media/video/samsung/mali/Makefile | 207 |
1 files changed, 126 insertions, 81 deletions
diff --git a/drivers/media/video/samsung/mali/Makefile b/drivers/media/video/samsung/mali/Makefile index 0ce60a3..db5ce6a 100644 --- a/drivers/media/video/samsung/mali/Makefile +++ b/drivers/media/video/samsung/mali/Makefile @@ -10,7 +10,7 @@ OSKOS :=linux FILES_PREFIX= -MALI_FILE_PREFIX := drivers/media/video/samsung/mali +MALI_INCLUDE_PREFIX := drivers/media/video/samsung/mali/ KBUILDROOT = ifeq ($(CONFIG_MALI_DED_ONLY),y) @@ -54,12 +54,8 @@ ifeq ($(CONFIG_VIDEO_MALI400MP_DEBUG),y) BUILD=debug endif -ifeq ($(CONFIG_VIDEO_MALI400MP_STREAMLINE_PROFILING),y) -USING_PROFILING=1 -USING_TRACEPOINTS=1 -endif - # set up defaults if not defined by the user +USE_UMPV2 ?= 0 PANIC_ON_WATCHDOG_TIMEOUT ?= 1 USING_MALI400 ?= 1 USING_MMU ?= 1 @@ -75,21 +71,47 @@ USING_MALI_PMU ?= 0 USING_GPU_UTILIZATION ?= 0 OS_MEMORY_KERNEL_BUFFER_SIZE_IN_MB ?= 6 USING_PROFILING ?= 0 +USING_INTERNAL_PROFILING ?= 0 USING_TRACEPOINTS ?= 0 USING_MALI_MAJOR_PREDEFINE = 1 -USING_MALI_DVFS_ENABLED ?= 0 +USING_MALI_DVFS_ENABLED ?= 1 TIMESTAMP ?= default BUILD ?= release USING_MALI_PMM_EARLYSUSPEND ?= 0 #USING_KERNEL_WITH_DMA_ALLOC_PHYS_PAGE ?= 0 -CONFIG_MALI_MEM_SIZE ?= 64 +CONFIG_MALI_MEM_SIZE ?= 512 +DISABLE_PP0 ?= 0 +DISABLE_PP1 ?= 0 +DISABLE_PP2 ?= 0 +DISABLE_PP3 ?= 0 +MALI_PP_SCHEDULER_FORCE_NO_JOB_OVERLAP ?= 0 +MALI_PP_SCHEDULER_KEEP_SUB_JOB_STARTS_ALIGNED ?= 0 +MALI_PP_SCHEDULER_FORCE_NO_JOB_OVERLAP_BETWEEN_APPS ?= 0 + +# Get path to driver source from Linux build system +ifeq ($(USING_PROFILING),1) +ifeq ($(USING_INTERNAL_PROFILING),0) +ifndef CONFIG_TRACEPOINTS +# Should default to gator profiling, but we dont have the kernel feature required, so disable profiling +USING_PROFILING = 0 +endif +endif +endif + +ifeq ($(USING_PROFILING),0) +# make sure user hasnt selected incompatible flags +USING_INTERNAL_PROFILING = 0 +endif + +USING_MALI_SLP_GLOBAL_LOCK ?= 0 #config validtion check ifeq ($(USING_OS_MEMORY),1) USING_MMU = 1 endif + # Check if a Mali Core sub module should be enabled, true or false returned -#submodule_enabled = $(shell gcc $(DEFINES) -E $(MALI_FILE_PREFIX)/arch/config.h | grep type | grep -c $(2)) +#submodule_enabled = $(shell gcc $(DEFINES) -E $(FILES_PREFIX)/arch/config.h | grep type | grep -c $(2)) # Inside the kernel build system @@ -111,14 +133,21 @@ DEFINES += -DMALI_GPU_UTILIZATION=$(USING_GPU_UTILIZATION) DEFINES += -DCONFIG_MALI_MEM_SIZE=$(CONFIG_MALI_MEM_SIZE) DEFINES += -D_MALI_OSK_SPECIFIC_INDIRECT_MMAP DEFINES += -DMALI_TIMELINE_PROFILING_ENABLED=$(USING_PROFILING) +DEFINES += -DMALI_INTERNAL_TIMELINE_PROFILING_ENABLED=$(USING_INTERNAL_PROFILING) DEFINES += -DMALI_POWER_MGMT_TEST_SUITE=$(USING_MALI_PMM_TESTSUITE) DEFINES += -DMALI_MAJOR_PREDEFINE=$(USING_MALI_MAJOR_PREDEFINE) DEFINES += -DMALI_DVFS_ENABLED=$(USING_MALI_DVFS_ENABLED) DEFINES += -DUSING_MALI_PMM_EARLYSUSPEND=$(USING_MALI_PMM_EARLYSUSPEND) -DEFINES += -DMALI_STATE_TRACKING=1 +DEFINES += -DMALI_STATE_TRACKING=0 DEFINES += -DMALI_OS_MEMORY_KERNEL_BUFFER_SIZE_IN_MB=$(OS_MEMORY_KERNEL_BUFFER_SIZE_IN_MB) DEFINES += -DMALI_TRACEPOINTS_ENABLED=$(USING_TRACEPOINTS) -DEFINES += -DMALI_REBOOTNOTIFIER +DEFINES += -DDISABLE_PP0=$(DISABLE_PP0) +DEFINES += -DDISABLE_PP1=$(DISABLE_PP1) +DEFINES += -DDISABLE_PP2=$(DISABLE_PP2) +DEFINES += -DDISABLE_PP3=$(DISABLE_PP3) +DEFINES += -DMALI_PP_SCHEDULER_FORCE_NO_JOB_OVERLAP=$(MALI_PP_SCHEDULER_FORCE_NO_JOB_OVERLAP) +DEFINES += -DMALI_PP_SCHEDULER_KEEP_SUB_JOB_STARTS_ALIGNED=$(MALI_PP_SCHEDULER_KEEP_SUB_JOB_STARTS_ALIGNED) +DEFINES += -DMALI_PP_SCHEDULER_FORCE_NO_JOB_OVERLAP_BETWEEN_APPS=$(MALI_PP_SCHEDULER_FORCE_NO_JOB_OVERLAP_BETWEEN_APPS) ifeq ($(BUILD),debug) DEFINES += -DDEBUG @@ -130,7 +159,7 @@ DEFINES += -DMALI_UKK_HAS_IMPLICIT_MMAP_CLEANUP # UMP ifeq ($(CONFIG_VIDEO_UMP),y) DEFINES += -DMALI_USE_UNIFIED_MEMORY_PROVIDER=1 -DHAVE_UNLOCKED_IOCTL - EXTRA_CFLAGS += -I$(MALI_FILE_PREFIX)/../ump/include + EXTRA_CFLAGS += -I$(MALI_INCLUDE_PREFIX)../ump/include else DEFINES += -DMALI_USE_UNIFIED_MEMORY_PROVIDER=0 endif @@ -141,17 +170,23 @@ obj-$(CONFIG_VIDEO_MALI400MP) += mali.o # Use our defines when compiling # MALI INCLUDES = \ - -I$(MALI_FILE_PREFIX)\ - -I$(MALI_FILE_PREFIX)/platform\ - -I$(MALI_FILE_PREFIX)/common \ - -I$(MALI_FILE_PREFIX)/linux + -I$(MALI_INCLUDE_PREFIX)\ + -I$(MALI_INCLUDE_PREFIX)include \ + -I$(MALI_INCLUDE_PREFIX)platform\ + -I$(MALI_INCLUDE_PREFIX)common \ + -I$(MALI_INCLUDE_PREFIX)linux \ + -I$(MALI_INCLUDE_PREFIX)regs + +ifeq ($(USING_PROFILING),1) +INCLUDES += \ + -I$(MALI_INCLUDE_PREFIX)include +endif EXTRA_CFLAGS += $(INCLUDES)\ $(DEFINES) - -EXTRA_CFLAGS += -I$(MALI_FILE_PREFIX)/linux/license/gpl -EXTRA_CFLAGS += -I$(MALI_FILE_PREFIX)/common/pmm +EXTRA_CFLAGS += -I$(MALI_INCLUDE_PREFIX)linux/license/gpl +EXTRA_CFLAGS += -I$(MALI_INCLUDE_PREFIX)common/pmm # Source files which always are included in a build ifeq ($(CONFIG_VIDEO_UMP),y) @@ -178,11 +213,12 @@ OSKFILES=\ endif #($(CONFIG_VIDEO_UMP),y) ifeq ($(CONFIG_CPU_EXYNOS4210),y) - MALI_PLATFORM_FILE = platform/orion-m400/mali_platform.o + MALI_PLATFORM_DIR = platform/orion-m400 else - MALI_PLATFORM_FILE = platform/pegasus-m400/mali_platform.o + MALI_PLATFORM_DIR = platform/pegasus-m400 endif #($(CONFIG_CPU_EXYNOS4210),y) +MALI_PLATFORM_FILE=$(MALI_PLATFORM_DIR)/mali_platform.o UKKFILES=\ $(FILES_PREFIX)$(OSKOS)/mali_ukk_mem.o \ $(FILES_PREFIX)$(OSKOS)/mali_ukk_gp.o \ @@ -190,85 +226,94 @@ UKKFILES=\ $(FILES_PREFIX)$(OSKOS)/mali_ukk_core.o \ $(FILES_PREFIX)$(OSKOS)/mali_ukk_vsync.o -mali-y := \ - $(KBUILDROOT)common/mali_kernel_core.o \ - $(KBUILDROOT)linux/mali_kernel_linux.o \ - $(KBUILDROOT)linux/mali_osk_indir_mmap.o \ - $(KBUILDROOT)common/mali_kernel_rendercore.o \ - $(KBUILDROOT)common/mali_kernel_descriptor_mapping.o \ - $(KBUILDROOT)common/mali_kernel_vsync.o \ - $(KBUILDROOT)linux/mali_kernel_sysfs.o \ - $(KBUILDROOT)$(MALI_PLATFORM_FILE) \ - $(KBUILDROOT)$(OSKFILES) \ - $(KBUILDROOT)$(UKKFILES) - #__malidrv_build_info.o - ifeq ($(USING_PROFILING),1) -EXTRA_CFLAGS += -I$(MALI_FILE_PREFIX)/timestamp-default -EXTRA_CFLAGS += -I$(MALI_FILE_PREFIX)/profiling/include -mali-y += \ - common/mali_kernel_profiling.o \ - timestamp-$(TIMESTAMP)/mali_timestamp.o \ - linux/mali_ukk_profiling.o - -EXTRA_CFLAGS += -I$(KBUILD_EXTMOD)/timestamp-$(TIMESTAMP) +UKKFILES += \ + $(FILES_PREFIX)$(OSKOS)/mali_ukk_profiling.o endif -ifeq ($(USING_TRACEPOINTS),1) -mali-y += \ - linux/mali_osk_profiling.o -endif +mali-y := \ + common/mali_kernel_core.o \ + linux/mali_kernel_linux.o \ + $(OSKOS)/mali_osk_indir_mmap.o \ + common/mali_kernel_descriptor_mapping.o \ + common/mali_session.o \ + common/mali_device_pause_resume.o \ + common/mali_kernel_vsync.o \ + linux/mali_ukk_vsync.o \ + linux/mali_kernel_sysfs.o \ + common/mali_mmu.o \ + common/mali_mmu_page_directory.o \ + common/mali_memory.o \ + common/mali_kernel_memory_engine.o \ + common/mali_block_allocator.o \ + common/mali_kernel_mem_os.o \ + common/mali_mem_validation.o \ + common/mali_hw_core.o \ + common/mali_gp.o \ + common/mali_pp.o \ + common/mali_pp_job.o \ + common/mali_gp_job.o \ + common/mali_scheduler.o \ + common/mali_gp_scheduler.o \ + common/mali_pp_scheduler.o \ + common/mali_cluster.o \ + common/mali_group.o \ + common/mali_dlbu.o \ + common/mali_pm.o \ + common/mali_pmu.o \ + common/mali_user_settings_db.o \ + $(OSKOS)/mali_osk_pm.o \ + linux/mali_kernel_pm.o \ + $(OSKOS)/mali_osk_wait_queue.o \ + $(MALI_PLATFORM_FILE) \ + $(OSKFILES) \ + $(UKKFILES) +# __malidrv_build_info.c # Selecting files to compile by parsing the config file -ifeq ($(USING_PMM),1) -mali-y += \ - common/pmm/mali_pmm.o \ - common/pmm/mali_pmm_policy.o \ - common/pmm/mali_pmm_policy_alwayson.o \ - common/pmm/mali_pmm_policy_jobcontrol.o \ - common/pmm/mali_pmm_state.o \ - linux/mali_kernel_pm.o \ - linux/mali_osk_pm.o \ - linux/mali_device_pause_resume.o +ifeq ($(USING_INTERNAL_PROFILING),1) +PROFILING_BACKEND_SOURCES = \ + linux/mali_osk_profiling_internal.o \ + timestamp-$(TIMESTAMP)/mali_timestamp.o +EXTRA_CFLAGS += -I$(MALI_INCLUDE_PREFIX)timestamp-$(TIMESTAMP) +else +ifeq ($(USING_PROFILING),1) +PROFILING_BACKEND_SOURCES = \ + linux/mali_osk_profiling_gator.o endif -ifeq ($(USING_MALI_PMU),1) -mali-y += \ - common/pmm/mali_pmm_pmu.o +endif + +# Add the profiling sources +mali-y += $(PROFILING_BACKEND_SOURCES) + +# Mali-400 PP in use +ifeq ($(USING_MALI_PMM_TESTSUITE),1) +EXTRA_CFLAGS += -I$(MALI_INCLUDE_PREFIX)platform/mali_pmu_testing endif ifeq ($(USING_GPU_UTILIZATION),1) +EXTRA_CFLAGS += -DCONFIG_MALI400_GPU_UTILIZATION=1 + mali-y += \ common/mali_kernel_utilization.o endif -# Mali-400 PP in use -EXTRA_CFLAGS += -DUSING_MALI400 -mali-y += common/mali_kernel_MALI200.o - -# Mali-400 GP in use -mali-y += common/mali_kernel_GP2.o +ifeq ($(USING_MALI_DVFS_ENABLED),1) +mali-y += $(MALI_PLATFORM_DIR)/mali_platform_dvfs.o +endif #($(USING_MALI_DVFS_ENABLED),1) -# Mali MMU in use -mali-y += \ - common/mali_kernel_mem_mmu.o \ - common/mali_kernel_memory_engine.o \ - common/mali_block_allocator.o \ - common/mali_kernel_mem_os.o +EXTRA_CFLAGS += -DUSING_MALI400 # Mali Level2 cache in use EXTRA_CFLAGS += -DUSING_MALI400_L2_CACHE -mali-y += common/mali_kernel_l2_cache.o - -ifeq ($(USING_MALI_DVFS_ENABLED),1) -ifeq ($(CONFIG_CPU_EXYNOS4210),y) +mali-y += common/mali_l2_cache.o +# Mali SLP Global lock feature +ifeq ($(USING_MALI_SLP_GLOBAL_LOCK),1) mali-y += \ - platform/orion-m400/mali_platform_dvfs.o -else -mali-y += \ - platform/pegasus-m400/mali_platform_dvfs.o -endif #($(CONFIG_CPU_EXYNOS4210),y) -endif #($(USING_MALI_DVFS_ENABLED),1) + linux/mali_slp_global_lock.o +endif + ifeq ($(PANIC_ON_WATCHDOG_TIMEOUT),1) EXTRA_CFLAGS += -DUSING_KERNEL_PANIC |