summaryrefslogtreecommitdiff
path: root/src/panfrost/lib/meson.build
diff options
context:
space:
mode:
Diffstat (limited to 'src/panfrost/lib/meson.build')
-rw-r--r--src/panfrost/lib/meson.build93
1 files changed, 42 insertions, 51 deletions
diff --git a/src/panfrost/lib/meson.build b/src/panfrost/lib/meson.build
index 021c8b98393..3a7318cd51b 100644
--- a/src/panfrost/lib/meson.build
+++ b/src/panfrost/lib/meson.build
@@ -19,20 +19,10 @@
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
# SOFTWARE.
-pan_packers = custom_target(
- 'midgard_pack.h',
- input : ['gen_pack.py', 'midgard.xml'],
- output : 'midgard_pack.h',
- command : [prog_python, '@INPUT@'],
- capture : true,
-)
-
-idep_pan_packers = declare_dependency(
- sources : [pan_packers],
- include_directories : include_directories('.'),
-)
+subdir('genxml')
+subdir('kmod')
-pixel_format_versions = ['6', '7']
+pixel_format_versions = ['5', '6', '7', '9']
libpanfrost_pixel_format = []
foreach ver : pixel_format_versions
@@ -40,43 +30,41 @@ foreach ver : pixel_format_versions
'pan-format-v' + ver,
['pan_format.c', pan_packers],
include_directories : [
- inc_src, inc_include, inc_gallium, inc_mesa, inc_panfrost_hw, inc_gallium_aux, inc_panfrost_hw
+ inc_src, inc_include, inc_panfrost_hw, inc_panfrost_hw
],
c_args : ['-DPAN_ARCH=' + ver],
gnu_symbol_visibility : 'hidden',
- dependencies : [idep_pan_packers, dep_libdrm],
+ dependencies : [idep_pan_packers, dep_libdrm, dep_valgrind],
)
endforeach
libpanfrost_per_arch = []
-libpanfrost_decode_per_arch = []
-foreach ver : ['4', '5', '6', '7']
+foreach ver : ['4', '5', '6', '7', '9', '10']
libpanfrost_per_arch += static_library(
'pan-arch-v' + ver,
[
'pan_blend.c',
'pan_blitter.c',
- 'pan_cs.c',
- 'pan_indirect_dispatch.c',
- 'pan_indirect_draw.c',
+ 'pan_desc.c',
'pan_shader.c',
'pan_texture.c',
],
- include_directories : [inc_include, inc_src, inc_mapi, inc_mesa, inc_gallium, inc_gallium_aux, inc_panfrost_hw],
+ include_directories : [inc_include, inc_src, inc_panfrost_hw],
c_args : ['-DPAN_ARCH=' + ver],
gnu_symbol_visibility : 'hidden',
dependencies : [dep_libdrm, idep_pan_packers, idep_nir],
)
+endforeach
- libpanfrost_decode_per_arch += static_library(
- 'pandecode-arch-v' + ver,
- ['decode.c', pan_packers],
- include_directories : [inc_include, inc_src, inc_panfrost],
- dependencies : [dep_libdrm, idep_pan_packers, idep_nir],
- c_args : [no_override_init_args, '-DPAN_ARCH=' + ver],
+foreach ver : ['7']
+ libpanfrost_per_arch += static_library(
+ 'pan-arch-indirect-v' + ver,
+ 'pan_indirect_dispatch.c',
+ include_directories : [inc_include, inc_src, inc_panfrost_hw],
+ c_args : ['-DPAN_ARCH=' + ver],
gnu_symbol_visibility : 'hidden',
- build_by_default : false,
+ dependencies : [dep_libdrm, idep_pan_packers, idep_nir],
)
endforeach
@@ -85,12 +73,12 @@ libpanfrost_lib_files = files(
'pan_afbc.c',
'pan_attributes.c',
- 'pan_bo.c',
'pan_blend.c',
'pan_clear.c',
+ 'pan_earlyzs.c',
'pan_samples.c',
'pan_tiler.c',
- 'pan_texture.c',
+ 'pan_layout.c',
'pan_scratch.c',
'pan_props.c',
'pan_util.c',
@@ -99,32 +87,18 @@ libpanfrost_lib_files = files(
libpanfrost_lib = static_library(
'panfrost_lib',
[libpanfrost_lib_files, pan_packers],
- include_directories : [inc_include, inc_src, inc_mapi, inc_mesa, inc_gallium, inc_gallium_aux, inc_panfrost_hw],
+ include_directories : [inc_include, inc_src, inc_panfrost_hw],
c_args : [no_override_init_args],
gnu_symbol_visibility : 'hidden',
- dependencies: [dep_libdrm, idep_nir],
+ dependencies: [dep_libdrm, idep_nir, idep_mesautil],
build_by_default : false,
- link_with: [libpanfrost_pixel_format, libpanfrost_per_arch],
-)
-
-libpanfrost_decode = static_library(
- 'panfrost_decode',
- [
- 'decode_common.c',
- pan_packers
- ],
- include_directories : [inc_include, inc_src, inc_mapi, inc_mesa, inc_gallium, inc_gallium_aux, inc_panfrost],
- dependencies : idep_mesautil,
- c_args : [no_override_init_args],
- gnu_symbol_visibility : 'hidden',
- build_by_default : false,
- link_with: [libpanfrost_decode_per_arch],
+ link_with: [libpanfrost_pixel_format, libpanfrost_per_arch, libpankmod_lib],
)
libpanfrost_dep = declare_dependency(
link_with: [libpanfrost_lib, libpanfrost_decode, libpanfrost_midgard, libpanfrost_bifrost, libpanfrost_pixel_format, libpanfrost_per_arch],
- include_directories: [inc_include, inc_src, inc_mapi, inc_mesa, inc_gallium, inc_gallium_aux, inc_panfrost_hw, inc_panfrost],
- dependencies: [dep_libdrm, idep_nir, idep_pan_packers],
+ include_directories: [inc_include, inc_src, inc_panfrost_hw, inc_panfrost],
+ dependencies: [dep_libdrm, libpankmod_dep, idep_nir, idep_pan_packers],
)
if with_tests
@@ -135,7 +109,7 @@ if with_tests
files('tests/test-blend.c'),
c_args : [c_msvc_compat_args, no_override_init_args],
gnu_symbol_visibility : 'hidden',
- include_directories : [inc_include, inc_src, inc_mesa],
+ include_directories : [inc_include, inc_src],
dependencies: [libpanfrost_dep],
),
suite : ['panfrost'],
@@ -148,9 +122,26 @@ if with_tests
files('tests/test-clear.c'),
c_args : [c_msvc_compat_args, no_override_init_args],
gnu_symbol_visibility : 'hidden',
- include_directories : [inc_include, inc_src, inc_mesa],
+ include_directories : [inc_include, inc_src],
dependencies: [libpanfrost_dep],
),
suite : ['panfrost'],
)
+
+ test(
+ 'panfrost_tests',
+ executable(
+ 'panfrost_tests',
+ files(
+ 'tests/test-earlyzs.cpp',
+ 'tests/test-layout.cpp',
+ ),
+ c_args : [c_msvc_compat_args, no_override_init_args],
+ gnu_symbol_visibility : 'hidden',
+ include_directories : [inc_include, inc_src, inc_panfrost],
+ dependencies: [idep_gtest, libpanfrost_dep],
+ ),
+ suite : ['panfrost'],
+ protocol : 'gtest',
+ )
endif