aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media/video/samsung/mali/Makefile
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/media/video/samsung/mali/Makefile')
-rw-r--r--drivers/media/video/samsung/mali/Makefile207
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