Clone of mesa.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

Makefile.am 12KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386
  1. # Copyright (C) 2015 Intel Corporation. All Rights Reserved.
  2. #
  3. # Permission is hereby granted, free of charge, to any person obtaining a
  4. # copy of this software and associated documentation files (the "Software"),
  5. # to deal in the Software without restriction, including without limitation
  6. # the rights to use, copy, modify, merge, publish, distribute, sublicense,
  7. # and/or sell copies of the Software, and to permit persons to whom the
  8. # Software is furnished to do so, subject to the following conditions:
  9. #
  10. # The above copyright notice and this permission notice (including the next
  11. # paragraph) shall be included in all copies or substantial portions of the
  12. # Software.
  13. #
  14. # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  15. # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  16. # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
  17. # THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  18. # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
  19. # FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
  20. # IN THE SOFTWARE.
  21. include Makefile.sources
  22. include $(top_srcdir)/src/gallium/Automake.inc
  23. AM_CXXFLAGS = $(GALLIUM_DRIVER_CFLAGS) $(CXX11_CXXFLAGS)
  24. noinst_LTLIBRARIES = libmesaswr.la
  25. libmesaswr_la_SOURCES = \
  26. $(CXX_SOURCES) \
  27. $(JITTER_CXX_SOURCES) \
  28. $(LOADER_SOURCES)
  29. COMMON_CXXFLAGS = \
  30. -fno-strict-aliasing \
  31. $(GALLIUM_DRIVER_CFLAGS) \
  32. $(LLVM_CXXFLAGS) \
  33. $(CXX11_CXXFLAGS) \
  34. -I$(builddir)/rasterizer/codegen \
  35. -I$(builddir)/rasterizer/core \
  36. -I$(builddir)/rasterizer/jitter \
  37. -I$(builddir)/rasterizer/archrast \
  38. -I$(srcdir)/rasterizer \
  39. -I$(srcdir)/rasterizer/core \
  40. -I$(srcdir)/rasterizer/codegen \
  41. -I$(srcdir)/rasterizer/jitter \
  42. -I$(srcdir)/rasterizer/archrast
  43. # SWR_AVX_CXXFLAGS needed for intrinsic usage in swr api headers
  44. libmesaswr_la_CXXFLAGS = \
  45. $(SWR_AVX_CXXFLAGS) \
  46. $(COMMON_CXXFLAGS)
  47. if HAVE_SWR_AVX
  48. libmesaswr_la_CXXFLAGS += -DHAVE_SWR_AVX
  49. endif
  50. if HAVE_SWR_AVX2
  51. libmesaswr_la_CXXFLAGS += -DHAVE_SWR_AVX2
  52. endif
  53. if HAVE_SWR_KNL
  54. libmesaswr_la_CXXFLAGS += -DHAVE_SWR_KNL
  55. endif
  56. if HAVE_SWR_SKX
  57. libmesaswr_la_CXXFLAGS += -DHAVE_SWR_SKX
  58. endif
  59. COMMON_SOURCES = \
  60. $(ARCHRAST_CXX_SOURCES) \
  61. $(COMMON_CXX_SOURCES) \
  62. $(CORE_CXX_SOURCES) \
  63. $(MEMORY_CXX_SOURCES) \
  64. $(BUILT_SOURCES)
  65. BUILT_SOURCES = \
  66. gen_swr_context_llvm.h \
  67. rasterizer/codegen/gen_knobs.cpp \
  68. rasterizer/codegen/gen_knobs.h \
  69. rasterizer/jitter/gen_state_llvm.h \
  70. rasterizer/jitter/gen_builder.hpp \
  71. rasterizer/jitter/gen_builder_x86.hpp \
  72. rasterizer/archrast/gen_ar_event.hpp \
  73. rasterizer/archrast/gen_ar_event.cpp \
  74. rasterizer/archrast/gen_ar_eventhandler.hpp \
  75. rasterizer/archrast/gen_ar_eventhandlerfile.hpp \
  76. rasterizer/core/backends/gen_BackendPixelRate0.cpp \
  77. rasterizer/core/backends/gen_BackendPixelRate1.cpp \
  78. rasterizer/core/backends/gen_BackendPixelRate2.cpp \
  79. rasterizer/core/backends/gen_BackendPixelRate3.cpp \
  80. rasterizer/core/backends/gen_BackendPixelRate.hpp \
  81. rasterizer/core/backends/gen_rasterizer0.cpp \
  82. rasterizer/core/backends/gen_rasterizer1.cpp \
  83. rasterizer/core/backends/gen_rasterizer2.cpp \
  84. rasterizer/core/backends/gen_rasterizer3.cpp \
  85. rasterizer/core/backends/gen_rasterizer.hpp
  86. MKDIR_GEN = $(AM_V_at)$(MKDIR_P) $(@D)
  87. PYTHON_GEN = $(AM_V_GEN)$(PYTHON2) $(PYTHON_FLAGS)
  88. gen_swr_context_llvm.h: rasterizer/codegen/gen_llvm_types.py rasterizer/codegen/templates/gen_llvm.hpp swr_context.h
  89. $(PYTHON_GEN) \
  90. $(srcdir)/rasterizer/codegen/gen_llvm_types.py \
  91. --input $(srcdir)/swr_context.h \
  92. --output ./gen_swr_context_llvm.h
  93. rasterizer/codegen/gen_knobs.cpp: rasterizer/codegen/gen_knobs.py rasterizer/codegen/knob_defs.py rasterizer/codegen/templates/gen_knobs.cpp rasterizer/codegen/gen_common.py
  94. $(MKDIR_GEN)
  95. $(PYTHON_GEN) \
  96. $(srcdir)/rasterizer/codegen/gen_knobs.py \
  97. --output rasterizer/codegen/gen_knobs.cpp \
  98. --gen_cpp
  99. rasterizer/codegen/gen_knobs.h: rasterizer/codegen/gen_knobs.py rasterizer/codegen/knob_defs.py rasterizer/codegen/templates/gen_knobs.h rasterizer/codegen/gen_common.py
  100. $(MKDIR_GEN)
  101. $(PYTHON_GEN) \
  102. $(srcdir)/rasterizer/codegen/gen_knobs.py \
  103. --output rasterizer/codegen/gen_knobs.h \
  104. --gen_h
  105. rasterizer/jitter/gen_state_llvm.h: rasterizer/codegen/gen_llvm_types.py rasterizer/codegen/templates/gen_llvm.hpp rasterizer/core/state.h rasterizer/codegen/gen_common.py
  106. $(MKDIR_GEN)
  107. $(PYTHON_GEN) \
  108. $(srcdir)/rasterizer/codegen/gen_llvm_types.py \
  109. --input $(srcdir)/rasterizer/core/state.h \
  110. --output rasterizer/jitter/gen_state_llvm.h
  111. rasterizer/jitter/gen_builder.hpp: rasterizer/codegen/gen_llvm_ir_macros.py rasterizer/codegen/templates/gen_builder.hpp rasterizer/codegen/gen_common.py
  112. $(MKDIR_GEN)
  113. $(PYTHON_GEN) \
  114. $(srcdir)/rasterizer/codegen/gen_llvm_ir_macros.py \
  115. --input $(LLVM_INCLUDEDIR)/llvm/IR/IRBuilder.h \
  116. --output rasterizer/jitter \
  117. --gen_h
  118. rasterizer/jitter/gen_builder_x86.hpp: rasterizer/codegen/gen_llvm_ir_macros.py rasterizer/codegen/templates/gen_builder.hpp rasterizer/codegen/gen_common.py
  119. $(MKDIR_GEN)
  120. $(PYTHON_GEN) \
  121. $(srcdir)/rasterizer/codegen/gen_llvm_ir_macros.py \
  122. --output rasterizer/jitter \
  123. --gen_x86_h
  124. rasterizer/archrast/gen_ar_event.hpp: rasterizer/codegen/gen_archrast.py rasterizer/codegen/templates/gen_ar_event.hpp rasterizer/archrast/events.proto rasterizer/archrast/events_private.proto rasterizer/codegen/gen_common.py
  125. $(MKDIR_GEN)
  126. $(PYTHON_GEN) \
  127. $(srcdir)/rasterizer/codegen/gen_archrast.py \
  128. --proto $(srcdir)/rasterizer/archrast/events.proto \
  129. --proto_private $(srcdir)/rasterizer/archrast/events_private.proto \
  130. --output rasterizer/archrast/gen_ar_event.hpp \
  131. --gen_event_hpp
  132. rasterizer/archrast/gen_ar_event.cpp: rasterizer/codegen/gen_archrast.py rasterizer/codegen/templates/gen_ar_event.cpp rasterizer/archrast/events.proto rasterizer/archrast/events_private.proto rasterizer/codegen/gen_common.py
  133. $(MKDIR_GEN)
  134. $(PYTHON_GEN) \
  135. $(srcdir)/rasterizer/codegen/gen_archrast.py \
  136. --proto $(srcdir)/rasterizer/archrast/events.proto \
  137. --proto_private $(srcdir)/rasterizer/archrast/events_private.proto \
  138. --output rasterizer/archrast/gen_ar_event.cpp \
  139. --gen_event_cpp
  140. rasterizer/archrast/gen_ar_eventhandler.hpp: rasterizer/codegen/gen_archrast.py rasterizer/codegen/templates/gen_ar_eventhandler.hpp rasterizer/archrast/events.proto rasterizer/archrast/events_private.proto rasterizer/codegen/gen_common.py
  141. $(MKDIR_GEN)
  142. $(PYTHON_GEN) \
  143. $(srcdir)/rasterizer/codegen/gen_archrast.py \
  144. --proto $(srcdir)/rasterizer/archrast/events.proto \
  145. --proto_private $(srcdir)/rasterizer/archrast/events_private.proto \
  146. --output rasterizer/archrast/gen_ar_eventhandler.hpp \
  147. --gen_eventhandler_hpp
  148. rasterizer/archrast/gen_ar_eventhandlerfile.hpp: rasterizer/codegen/gen_archrast.py rasterizer/codegen/templates/gen_ar_eventhandlerfile.hpp rasterizer/archrast/events.proto rasterizer/archrast/events_private.proto rasterizer/codegen/gen_common.py
  149. $(MKDIR_GEN)
  150. $(PYTHON_GEN) \
  151. $(srcdir)/rasterizer/codegen/gen_archrast.py \
  152. --proto $(srcdir)/rasterizer/archrast/events.proto \
  153. --proto_private $(srcdir)/rasterizer/archrast/events_private.proto \
  154. --output rasterizer/archrast/gen_ar_eventhandlerfile.hpp \
  155. --gen_eventhandlerfile_hpp
  156. rasterizer/core/backends/gen_BackendPixelRate0.cpp \
  157. rasterizer/core/backends/gen_BackendPixelRate1.cpp \
  158. rasterizer/core/backends/gen_BackendPixelRate2.cpp \
  159. rasterizer/core/backends/gen_BackendPixelRate3.cpp \
  160. rasterizer/core/backends/gen_BackendPixelRate.hpp: \
  161. backend.intermediate
  162. # 5 SWR_MULTISAMPLE_TYPE_COUNT
  163. # 2 SWR_MSAA_SAMPLE_PATTERN_COUNT
  164. # 3 SWR_INPUT_COVERAGE_COUNT
  165. # 2 centroid
  166. # 2 forcedSampleCount
  167. # 2 canEarlyZ
  168. # use intermediate rule to tell make that all files can be
  169. # generated in one invocation of gen_backends.py (prevents
  170. # parallel make race condition)
  171. .INTERMEDIATE: backend.intermediate
  172. backend.intermediate: rasterizer/codegen/gen_backends.py rasterizer/codegen/templates/gen_backend.cpp rasterizer/codegen/templates/gen_header_init.hpp
  173. $(MKDIR_GEN)
  174. $(PYTHON_GEN) \
  175. $(srcdir)/rasterizer/codegen/gen_backends.py \
  176. --outdir rasterizer/core/backends \
  177. --dim 5 2 3 2 2 2 \
  178. --numfiles 4 \
  179. --cpp \
  180. --hpp
  181. rasterizer/core/backends/gen_rasterizer0.cpp \
  182. rasterizer/core/backends/gen_rasterizer1.cpp \
  183. rasterizer/core/backends/gen_rasterizer2.cpp \
  184. rasterizer/core/backends/gen_rasterizer3.cpp \
  185. rasterizer/core/backends/gen_rasterizer.hpp: \
  186. rasterizer.intermediate
  187. # 5 SWR_MULTISAMPLE_TYPE_COUNT
  188. # 2 CenterPattern
  189. # 2 Conservative
  190. # 3 SWR_INPUT_COVERAGE_COUNT
  191. # 5 STATE_VALID_TRI_EDGE_COUNT
  192. # 2 RasterScissorEdges
  193. # use intermediate rule to tell make that all files can be
  194. # generated in one invocation of gen_backends.py (prevents
  195. # parallel make race condition)
  196. .INTERMEDIATE: rasterizer.intermediate
  197. rasterizer.intermediate: rasterizer/codegen/gen_backends.py rasterizer/codegen/templates/gen_rasterizer.cpp rasterizer/codegen/templates/gen_header_init.hpp
  198. $(MKDIR_GEN)
  199. $(PYTHON_GEN) \
  200. $(srcdir)/rasterizer/codegen/gen_backends.py \
  201. --outdir rasterizer/core/backends \
  202. --rast \
  203. --dim 5 2 2 3 5 2 \
  204. --numfiles 4 \
  205. --cpp \
  206. --hpp
  207. COMMON_LDFLAGS = \
  208. -shared \
  209. -module \
  210. -no-undefined \
  211. $(GC_SECTIONS) \
  212. $(LD_NO_UNDEFINED)
  213. lib_LTLIBRARIES =
  214. if HAVE_SWR_AVX
  215. libswrAVX_la_CXXFLAGS = \
  216. $(PTHREAD_CFLAGS) \
  217. $(SWR_AVX_CXXFLAGS) \
  218. -DKNOB_ARCH=KNOB_ARCH_AVX \
  219. $(COMMON_CXXFLAGS)
  220. libswrAVX_la_SOURCES = \
  221. $(COMMON_SOURCES)
  222. libswrAVX_la_LIBADD = \
  223. $(PTHREAD_LIBS)
  224. libswrAVX_la_LDFLAGS = \
  225. $(COMMON_LDFLAGS)
  226. endif
  227. if HAVE_SWR_AVX2
  228. libswrAVX2_la_CXXFLAGS = \
  229. $(PTHREAD_CFLAGS) \
  230. $(SWR_AVX2_CXXFLAGS) \
  231. -DKNOB_ARCH=KNOB_ARCH_AVX2 \
  232. $(COMMON_CXXFLAGS)
  233. libswrAVX2_la_SOURCES = \
  234. $(COMMON_SOURCES)
  235. libswrAVX2_la_LIBADD = \
  236. $(PTHREAD_LIBS)
  237. libswrAVX2_la_LDFLAGS = \
  238. $(COMMON_LDFLAGS)
  239. endif
  240. if HAVE_SWR_KNL
  241. libswrKNL_la_CXXFLAGS = \
  242. $(PTHREAD_CFLAGS) \
  243. $(SWR_KNL_CXXFLAGS) \
  244. -DKNOB_ARCH=KNOB_ARCH_AVX512 -DSIMD_ARCH_KNIGHTS \
  245. $(COMMON_CXXFLAGS)
  246. libswrKNL_la_SOURCES = \
  247. $(COMMON_SOURCES)
  248. libswrKNL_la_LIBADD = \
  249. $(PTHREAD_LIBS)
  250. libswrKNL_la_LDFLAGS = \
  251. $(COMMON_LDFLAGS)
  252. endif
  253. if HAVE_SWR_SKX
  254. libswrSKX_la_CXXFLAGS = \
  255. $(PTHREAD_CFLAGS) \
  256. $(SWR_SKX_CXXFLAGS) \
  257. -DKNOB_ARCH=KNOB_ARCH_AVX512 \
  258. $(COMMON_CXXFLAGS)
  259. libswrSKX_la_SOURCES = \
  260. $(COMMON_SOURCES)
  261. libswrSKX_la_LIBADD = \
  262. $(PTHREAD_LIBS)
  263. libswrSKX_la_LDFLAGS = \
  264. $(COMMON_LDFLAGS)
  265. endif
  266. if HAVE_SWR_BUILTIN
  267. libmesaswr_la_CXXFLAGS += -DHAVE_SWR_BUILTIN
  268. libmesaswr_la_LIBADD =
  269. if HAVE_SWR_AVX
  270. noinst_LTLIBRARIES += libswrAVX.la
  271. libmesaswr_la_LIBADD += libswrAVX.la
  272. endif
  273. if HAVE_SWR_AVX2
  274. noinst_LTLIBRARIES += libswrAVX2.la
  275. libmesaswr_la_LIBADD += libswrAVX2.la
  276. endif
  277. if HAVE_SWR_KNL
  278. noinst_LTLIBRARIES += libswrKNL.la
  279. libmesaswr_la_LIBADD += libswrKNL.la
  280. endif
  281. if HAVE_SWR_SKX
  282. noinst_LTLIBRARIES += libswrSKX.la
  283. libmesaswr_la_LIBADD += libswrSKX.la
  284. endif
  285. else # !HAVE_SWR_BUILTIN
  286. # gen_knobs.* included here to provide driver access to swr configuration
  287. libmesaswr_la_SOURCES += \
  288. $(COMMON_CXX_SOURCES) \
  289. rasterizer/codegen/gen_knobs.cpp \
  290. rasterizer/codegen/gen_knobs.h
  291. if HAVE_SWR_AVX
  292. lib_LTLIBRARIES += libswrAVX.la
  293. endif
  294. if HAVE_SWR_AVX2
  295. lib_LTLIBRARIES += libswrAVX2.la
  296. endif
  297. if HAVE_SWR_KNL
  298. lib_LTLIBRARIES += libswrKNL.la
  299. endif
  300. if HAVE_SWR_SKX
  301. lib_LTLIBRARIES += libswrSKX.la
  302. endif
  303. endif
  304. include $(top_srcdir)/install-gallium-links.mk
  305. # Generated gen_builder.hpp is not backwards compatible. So ship only one
  306. # created with the oldest supported version of LLVM.
  307. dist-hook:
  308. if SWR_INVALID_LLVM_VERSION
  309. @echo "*******************************************************"
  310. @echo "LLVM 4.0.0 or LLVM 4.0.1 required to create the tarball"
  311. @echo "*******************************************************"
  312. @test
  313. endif
  314. EXTRA_DIST = \
  315. SConscript \
  316. meson.build \
  317. rasterizer/codegen/meson.build \
  318. rasterizer/archrast/events.proto \
  319. rasterizer/codegen/gen_llvm_ir_macros.py \
  320. rasterizer/codegen/gen_llvm_types.py \
  321. rasterizer/codegen/gen_archrast.py \
  322. rasterizer/codegen/gen_backends.py \
  323. rasterizer/codegen/gen_common.py \
  324. rasterizer/codegen/gen_knobs.py \
  325. rasterizer/codegen/knob_defs.py \
  326. rasterizer/codegen/templates/gen_ar_event.cpp \
  327. rasterizer/codegen/templates/gen_ar_event.hpp \
  328. rasterizer/codegen/templates/gen_ar_eventhandler.hpp \
  329. rasterizer/codegen/templates/gen_ar_eventhandlerfile.hpp \
  330. rasterizer/codegen/templates/gen_backend.cpp \
  331. rasterizer/codegen/templates/gen_builder.hpp \
  332. rasterizer/codegen/templates/gen_header_init.hpp \
  333. rasterizer/codegen/templates/gen_knobs.cpp \
  334. rasterizer/codegen/templates/gen_knobs.h \
  335. rasterizer/codegen/templates/gen_llvm.hpp \
  336. rasterizer/codegen/templates/gen_rasterizer.cpp