Kbuild 8.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223
  1. #
  2. # This confidential and proprietary software may be used only as
  3. # authorised by a licensing agreement from ARM Limited
  4. # (C) COPYRIGHT 2007-2011 ARM Limited
  5. # ALL RIGHTS RESERVED
  6. # The entire notice above must be reproduced on all authorised
  7. # copies and copies may only be made to the extent permitted
  8. # by a licensing agreement from ARM Limited.
  9. #
  10. # This file is called by the Linux build system.
  11. # set up defaults if not defined by the user
  12. TIMESTAMP ?= default
  13. OS_MEMORY_KERNEL_BUFFER_SIZE_IN_MB ?= 16
  14. USING_GPU_UTILIZATION ?= 1
  15. PROFILING_SKIP_PP_JOBS ?= 0
  16. PROFILING_SKIP_PP_AND_GP_JOBS ?= 0
  17. MALI_PP_SCHEDULER_FORCE_NO_JOB_OVERLAP ?= 0
  18. MALI_PP_SCHEDULER_KEEP_SUB_JOB_STARTS_ALIGNED ?= 0
  19. MALI_PP_SCHEDULER_FORCE_NO_JOB_OVERLAP_BETWEEN_APPS ?= 0
  20. MALI_UPPER_HALF_SCHEDULING ?= 1
  21. MALI_ENABLE_CPU_CYCLES ?= 0
  22. # For customer releases the Linux Device Drivers will be provided as ARM proprietary and GPL releases:
  23. # The ARM proprietary product will only include the license/proprietary directory
  24. # The GPL product will only include the license/gpl directory
  25. ifeq ($(wildcard $(srctree)/$(src)/linux/license/gpl/*),)
  26. ccflags-y += -I$(srctree)/$(src)/linux/license/proprietary
  27. ifeq ($(CONFIG_MALI400_PROFILING),y)
  28. $(error Profiling is incompatible with non-GPL license)
  29. endif
  30. ifeq ($(CONFIG_PM_RUNTIME),y)
  31. $(error Runtime PM is incompatible with non-GPL license)
  32. endif
  33. ifeq ($(CONFIG_DMA_SHARED_BUFFER),y)
  34. $(error DMA-BUF is incompatible with non-GPL license)
  35. endif
  36. $(error Linux Device integration is incompatible with non-GPL license)
  37. else
  38. ccflags-y += -I$(srctree)/$(src)/linux/license/gpl
  39. endif
  40. ifeq ($(MALI_PLATFORM_FILES),)
  41. EXTRA_DEFINES += -DMALI_FAKE_PLATFORM_DEVICE=1
  42. export MALI_PLATFORM=arm
  43. export MALI_PLATFORM_FILES_BUILDIN = $(notdir $(wildcard $(srctree)/$(src)/platform/$(MALI_PLATFORM)/*.c))
  44. export MALI_PLATFORM_FILES_ADD_PREFIX = $(addprefix platform/$(MALI_PLATFORM)/,$(MALI_PLATFORM_FILES_BUILDIN))
  45. endif
  46. mali-y += \
  47. linux/mali_osk_atomics.o \
  48. linux/mali_osk_irq.o \
  49. linux/mali_osk_wq.o \
  50. linux/mali_osk_locks.o \
  51. linux/mali_osk_wait_queue.o \
  52. linux/mali_osk_low_level_mem.o \
  53. linux/mali_osk_math.o \
  54. linux/mali_osk_memory.o \
  55. linux/mali_osk_misc.o \
  56. linux/mali_osk_mali.o \
  57. linux/mali_osk_notification.o \
  58. linux/mali_osk_time.o \
  59. linux/mali_osk_timers.o
  60. mali-y += linux/mali_memory.o linux/mali_memory_os_alloc.o
  61. mali-y += linux/mali_memory_external.o
  62. mali-y += linux/mali_memory_block_alloc.o
  63. mali-y += \
  64. linux/mali_ukk_mem.o \
  65. linux/mali_ukk_gp.o \
  66. linux/mali_ukk_pp.o \
  67. linux/mali_ukk_core.o \
  68. linux/mali_ukk_soft_job.o \
  69. linux/mali_ukk_timeline.o
  70. # Source files which always are included in a build
  71. mali-y += \
  72. common/mali_kernel_core.o \
  73. linux/mali_kernel_linux.o \
  74. common/mali_kernel_descriptor_mapping.o \
  75. common/mali_session.o \
  76. linux/mali_device_pause_resume.o \
  77. common/mali_kernel_vsync.o \
  78. linux/mali_ukk_vsync.o \
  79. linux/mali_kernel_sysfs.o \
  80. common/mali_mmu.o \
  81. common/mali_mmu_page_directory.o \
  82. common/mali_mem_validation.o \
  83. common/mali_hw_core.o \
  84. common/mali_gp.o \
  85. common/mali_pp.o \
  86. common/mali_pp_job.o \
  87. common/mali_gp_job.o \
  88. common/mali_soft_job.o \
  89. common/mali_scheduler.o \
  90. common/mali_gp_scheduler.o \
  91. common/mali_pp_scheduler.o \
  92. common/mali_group.o \
  93. common/mali_dlbu.o \
  94. common/mali_broadcast.o \
  95. common/mali_pm.o \
  96. common/mali_pmu.o \
  97. common/mali_user_settings_db.o \
  98. common/mali_kernel_utilization.o \
  99. common/mali_l2_cache.o \
  100. common/mali_dma.o \
  101. common/mali_timeline.o \
  102. common/mali_timeline_fence_wait.o \
  103. common/mali_timeline_sync_fence.o \
  104. common/mali_spinlock_reentrant.o \
  105. common/mali_pm_domain.o \
  106. linux/mali_osk_pm.o \
  107. linux/mali_pmu_power_up_down.o \
  108. __malidrv_build_info.o
  109. ifneq ($(MALI_PLATFORM_FILES),)
  110. mali-y += $(MALI_PLATFORM_FILES:.c=.o)
  111. endif
  112. ifneq ($(MALI_PLATFORM_FILES_ADD_PREFIX),)
  113. mali-y += $(MALI_PLATFORM_FILES_ADD_PREFIX:.c=.o)
  114. endif
  115. mali-$(CONFIG_MALI400_PROFILING) += linux/mali_ukk_profiling.o
  116. mali-$(CONFIG_MALI400_PROFILING) += linux/mali_osk_profiling.o
  117. mali-$(CONFIG_MALI400_INTERNAL_PROFILING) += linux/mali_profiling_internal.o timestamp-$(TIMESTAMP)/mali_timestamp.o
  118. ccflags-$(CONFIG_MALI400_INTERNAL_PROFILING) += -I$(srctree)/$(src)/timestamp-$(TIMESTAMP)
  119. mali-$(CONFIG_DMA_SHARED_BUFFER) += linux/mali_memory_dma_buf.o
  120. mali-$(CONFIG_SYNC) += linux/mali_sync.o
  121. mali-$(CONFIG_MALI400_UMP) += linux/mali_memory_ump.o
  122. mali-$(CONFIG_MALI400_POWER_PERFORMANCE_POLICY) += common/mali_power_performance_policy.o
  123. # Tell the Linux build system from which .o file to create the kernel module
  124. obj-$(CONFIG_MALI400) := mali.o
  125. ccflags-y += $(EXTRA_DEFINES)
  126. # Set up our defines, which will be passed to gcc
  127. ccflags-y += -DPROFILING_SKIP_PP_JOBS=$(PROFILING_SKIP_PP_JOBS)
  128. ccflags-y += -DPROFILING_SKIP_PP_AND_GP_JOBS=$(PROFILING_SKIP_PP_AND_GP_JOBS)
  129. ccflags-y += -DMALI_PP_SCHEDULER_FORCE_NO_JOB_OVERLAP=$(MALI_PP_SCHEDULER_FORCE_NO_JOB_OVERLAP)
  130. ccflags-y += -DMALI_PP_SCHEDULER_KEEP_SUB_JOB_STARTS_ALIGNED=$(MALI_PP_SCHEDULER_KEEP_SUB_JOB_STARTS_ALIGNED)
  131. ccflags-y += -DMALI_PP_SCHEDULER_FORCE_NO_JOB_OVERLAP_BETWEEN_APPS=$(MALI_PP_SCHEDULER_FORCE_NO_JOB_OVERLAP_BETWEEN_APPS)
  132. ccflags-y += -DMALI_STATE_TRACKING=1
  133. ccflags-y += -DMALI_OS_MEMORY_KERNEL_BUFFER_SIZE_IN_MB=$(OS_MEMORY_KERNEL_BUFFER_SIZE_IN_MB)
  134. ccflags-y += -DUSING_GPU_UTILIZATION=$(USING_GPU_UTILIZATION)
  135. ccflags-y += -DMALI_ENABLE_CPU_CYCLES=$(MALI_ENABLE_CPU_CYCLES)
  136. ifeq ($(MALI_UPPER_HALF_SCHEDULING),1)
  137. ccflags-y += -DMALI_UPPER_HALF_SCHEDULING
  138. endif
  139. ccflags-$(CONFIG_MALI400_UMP) += -I$(srctree)/$(src)/../../ump/include/ump
  140. ccflags-$(CONFIG_MALI400_DEBUG) += -DDEBUG
  141. # Use our defines when compiling
  142. ccflags-y += -I$(srctree)/$(src) -I$(srctree)/$(src)/include -I$(srctree)/$(src)/common -I$(srctree)/$(src)/linux -I$(srctree)/$(src)/platform -Wno-date-time
  143. # Get subversion revision number, fall back to only ${MALI_RELEASE_NAME} if no svn info is available
  144. MALI_RELEASE_NAME=$(shell cat $(srctree)/$(src)/.version 2> /dev/null)
  145. SVN_INFO = (cd $(srctree)/$(src); svn info 2>/dev/null)
  146. ifneq ($(shell $(SVN_INFO) 2>/dev/null),)
  147. # SVN detected
  148. SVN_REV := $(shell $(SVN_INFO) | grep '^Revision: '| sed -e 's/^Revision: //' 2>/dev/null)
  149. DRIVER_REV := $(MALI_RELEASE_NAME)-r$(SVN_REV)
  150. CHANGE_DATE := $(shell $(SVN_INFO) | grep '^Last Changed Date: ' | cut -d: -f2- | cut -b2-)
  151. CHANGED_REVISION := $(shell $(SVN_INFO) | grep '^Last Changed Rev: ' | cut -d: -f2- | cut -b2-)
  152. REPO_URL := $(shell $(SVN_INFO) | grep '^URL: ' | cut -d: -f2- | cut -b2-)
  153. else # SVN
  154. GIT_REV := $(shell cd $(srctree)/$(src); git describe --always 2>/dev/null)
  155. ifneq ($(GIT_REV),)
  156. # Git detected
  157. DRIVER_REV := $(MALI_RELEASE_NAME)-$(GIT_REV)
  158. CHANGE_DATE := $(shell cd $(srctree)/$(src); git log -1 --format="%ci")
  159. CHANGED_REVISION := $(GIT_REV)
  160. REPO_URL := $(shell cd $(srctree)/$(src); git describe --all --always 2>/dev/null)
  161. else # Git
  162. # No Git or SVN detected
  163. DRIVER_REV := $(MALI_RELEASE_NAME)
  164. CHANGE_DATE := $(MALI_RELEASE_NAME)
  165. CHANGED_REVISION := $(MALI_RELEASE_NAME)
  166. endif
  167. endif
  168. ccflags-y += -DSVN_REV_STRING=\"$(DRIVER_REV)\"
  169. VERSION_STRINGS :=
  170. VERSION_STRINGS += API_VERSION=$(shell cd $(srctree)/$(src); grep "\#define _MALI_API_VERSION" $(FILES_PREFIX)include/linux/mali/mali_utgard_uk_types.h | cut -d' ' -f 3 )
  171. VERSION_STRINGS += REPO_URL=$(REPO_URL)
  172. VERSION_STRINGS += REVISION=$(DRIVER_REV)
  173. VERSION_STRINGS += CHANGED_REVISION=$(CHANGED_REVISION)
  174. VERSION_STRINGS += CHANGE_DATE=$(CHANGE_DATE)
  175. VERSION_STRINGS += BUILD_DATE=$(shell date)
  176. ifdef CONFIG_MALI400_DEBUG
  177. VERSION_STRINGS += BUILD=debug
  178. else
  179. VERSION_STRINGS += BUILD=release
  180. endif
  181. VERSION_STRINGS += TARGET_PLATFORM=$(TARGET_PLATFORM)
  182. VERSION_STRINGS += MALI_PLATFORM=$(MALI_PLATFORM)
  183. VERSION_STRINGS += KDIR=$(KDIR)
  184. VERSION_STRINGS += OS_MEMORY_KERNEL_BUFFER_SIZE_IN_MB=$(OS_MEMORY_KERNEL_BUFFER_SIZE_IN_MB)
  185. VERSION_STRINGS += USING_UMP=$(CONFIG_MALI400_UMP)
  186. VERSION_STRINGS += USING_PROFILING=$(CONFIG_MALI400_PROFILING)
  187. VERSION_STRINGS += USING_INTERNAL_PROFILING=$(CONFIG_MALI400_INTERNAL_PROFILING)
  188. VERSION_STRINGS += USING_GPU_UTILIZATION=$(USING_GPU_UTILIZATION)
  189. VERSION_STRINGS += USING_POWER_PERFORMANCE_POLICY=$(CONFIG_POWER_PERFORMANCE_POLICY)
  190. VERSION_STRINGS += MALI_UPPER_HALF_SCHEDULING=$(MALI_UPPER_HALF_SCHEDULING)
  191. # Create file with Mali driver configuration
  192. $(srctree)/$(src)/__malidrv_build_info.c:
  193. @echo 'const char *__malidrv_build_info(void) { return "malidrv: $(VERSION_STRINGS)";}' > $(srctree)/$(src)/__malidrv_build_info.c