X-Git-Url: https://git.libre-soc.org/?a=blobdiff_plain;f=meson.build;h=ebaf2d957fd925b024badffdd0ff51e9d9795d7a;hb=66f97f6640f5316b36177fd1053f0027eb6ec6cc;hp=2f73215ca5248714b2f73fe3f92f7faef2532b83;hpb=e21e0a6a70b84f384ac7b80b88415e8fa519026d;p=mesa.git diff --git a/meson.build b/meson.build index 2f73215ca52..ebaf2d957fd 100644 --- a/meson.build +++ b/meson.build @@ -31,12 +31,14 @@ pre_args = [ '-DVERSION="@0@"'.format(meson.project_version()), '-DPACKAGE_VERSION=VERSION', '-DPACKAGE_BUGREPORT="https://bugs.freedesktop.org/enter_bug.cgi?product=Mesa"', + '-D_GNU_SOURCE', ] with_vulkan_icd_dir = get_option('vulkan-icd-dir') with_tests = get_option('build-tests') with_valgrind = get_option('valgrind') with_asm = get_option('asm') +with_llvm = get_option('llvm') if get_option('texture-float') pre_args += '-DTEXTURE_FLOAT_ENABLED' message('WARNING: Floating-point texture enabled. Please consult docs/patents.txt and your lawyer before building mesa.') @@ -88,12 +90,18 @@ if _drivers != '' with_dri = true endif -dep_libdrm_intel = [] -if with_dri_i915 - dep_libdrm_intel = dependency('libdrm_intel', version : '>= 2.4.75') +with_gallium = false +with_gallium_radeonsi = false +with_gallium_softpipe = false +_drivers = get_option('gallium-drivers') +if _drivers != '' + _split = _drivers.split(',') + with_gallium_radeonsi = _split.contains('radeonsi') + with_gallium = true + with_dri = true endif -if not with_dri +if not (with_dri or with_gallium) with_gles1 = false with_gles2 = false with_opengl = false @@ -101,41 +109,24 @@ if not with_dri with_shared_glapi = false endif +dep_libdrm_intel = [] +if with_dri_i915 + dep_libdrm_intel = dependency('libdrm_intel', version : '>= 2.4.75') +endif + # TODO: other OSes with_dri_platform = 'drm' -with_gallium = false -# TODO: gallium drivers - -# TODO: conditionalize libdrm requirement -dep_libdrm = dependency('libdrm', version : '>= 2.4.75') -pre_args += '-DHAVE_LIBDRM' - -with_dri2 = with_dri_platform == 'drm' and dep_libdrm.found() -with_dri3 = get_option('dri3') -if with_dri3 == 'auto' - if host_machine.system() == 'linux' and with_dri2 - with_dri3 = true - else - with_dri3 = false - endif -elif with_dri3 == 'yes' - if not with_dri2 - error('dri3 support requires libdrm') - endif - with_dri3 = true -else - with_dri3 = false -endif - # TODO: there are more platforms required for non-vulkan drivers with_platform_wayland = false with_platform_x11 = false +with_platform_drm = false _platforms = get_option('platforms') if _platforms != '' _split = _platforms.split(',') with_platform_x11 = _split.contains('x11') with_platform_wayland = _split.contains('wayland') + with_platform_drm = _split.contains('drm') endif with_gbm = get_option('gbm') @@ -150,9 +141,9 @@ else with_gbm = false endif +pre_args += '-DGLX_USE_TLS' with_glx = get_option('glx') if with_glx != 'disabled' - pre_args += '-DGLX_USE_TLS' if not (with_platform_x11 and with_any_opengl) and with_glx != 'auto' error('Cannot build GLX support without X11 platform support and at least one OpenGL API') elif with_glx == 'gallium-xlib' @@ -200,17 +191,69 @@ if _vulkan_drivers != '' if not (with_platform_x11 or with_platform_wayland) error('Vulkan requires at least one platform (x11, wayland)') endif - if with_platform_x11 and not with_dri3 - error('Vulkan drivers require dri3 for X11 support') - endif endif -if with_dri # TODO: or gallium +with_dri2 = (with_dri or with_any_vk) and with_dri_platform == 'drm' +with_dri3 = get_option('dri3') +if with_dri3 == 'auto' + if host_machine.system() == 'linux' and with_dri2 + with_dri3 = true + else + with_dri3 = false + endif +elif with_dri3 == 'yes' + with_dri3 = true +else + with_dri3 = false +endif + +if with_any_vk and (with_platform_x11 and not with_dri3) + error('Vulkan drivers require dri3 for X11 support') +endif +if with_dri or with_gallium if with_glx == 'disabled' # TODO: or egl error('building dri or gallium drivers require at least one window system') endif endif +with_gallium_xvmc = false +with_gallium_vdpau = false +with_gallium_omx = false # this is bellagio +with_gallium_va = false +with_gallium_media = false +dep_va = [] +_drivers = get_option('gallium-media') +if _drivers != '' + _split = _drivers.split(',') + with_gallium_xvmc = _split.contains('xvmc') + with_gallium_vdpau = _split.contains('vdpau') + with_gallium_omx = _split.contains('omx') + with_gallium_va = _split.contains('va') + with_gallium_media = (with_gallium_xvmc or with_gallium_vdpau or + with_gallium_omx or with_gallium_va) +endif + +if with_platform_x11 + if with_any_vk or (with_glx == 'dri' and with_dri_platform == 'drm') + pre_args += '-DHAVE_X11_PLATFORM' + endif + if with_glx == 'xlib' + # TODO + error('TODO') + elif with_glx == 'gallium-xlib' + # TODO + error('TODO') + else + pre_args += '-DGLX_INDIRECT_RENDERING' + if with_glx_direct + pre_args += '-DGLX_DIRECT_RENDERING' + endif + if with_dri_platform == 'drm' + pre_args += '-DGLX_USE_DRM' + endif + endif +endif + prog_python2 = find_program('python2') has_mako = run_command(prog_python2, '-c', 'import mako') if has_mako.returncode() != 0 @@ -480,10 +523,18 @@ else dep_clock = cc.find_library('rt') endif +dep_libdrm = dependency('libdrm', version : '>= 2.4.75', + required : with_dri2 or with_dri3) +if dep_libdrm.found() + pre_args += '-DHAVE_LIBDRM' +endif + # TODO: some of these may be conditional dep_zlib = dependency('zlib', version : '>= 1.2.3') dep_thread = dependency('threads') -pre_args += '-DHAVE_PTHREAD' +if dep_thread.found() and host_machine.system() == 'linux' + pre_args += '-DHAVE_PTHREAD' +endif dep_elf = dependency('libelf', required : false) if not dep_elf.found() dep_elf = cc.find_library('elf', required : with_amd_vk) # TODO: clover, r600, radeonsi @@ -494,8 +545,12 @@ dep_expat = dependency('expat') dep_m = cc.find_library('m', required : false) dep_libdrm_amdgpu = [] -if with_amd_vk - dep_libdrm_amdgpu = dependency('libdrm_amdgpu', version : '>= 2.4.82') +dep_libdrm_radeon = [] +if with_amd_vk or with_gallium_radeonsi + dep_libdrm_amdgpu = dependency('libdrm_amdgpu', version : '>= 2.4.84') +endif +if with_gallium_radeonsi # older radeon too + dep_libdrm_radeon = dependency('libdrm_radeon', version : '>= 2.4.71') endif llvm_modules = ['bitwriter', 'engine', 'mcdisassembler', 'mcjit'] @@ -503,24 +558,28 @@ if with_amd_vk llvm_modules += ['amdgpu', 'bitreader', 'ipo'] endif dep_llvm = dependency( - 'llvm', version : '>= 3.9.0', required : false, modules : llvm_modules, + 'llvm', version : '>= 3.9.0', required : with_amd_vk, modules : llvm_modules, ) -if not dep_llvm.found() - if with_amd_vk - error('Radv requires llvm.') - endif -else - _llvm_version = dep_llvm.version().split('.') - # Development versions of LLVM have an 'svn' suffix, we don't want that for - # our version checks. - _llvm_patch = _llvm_version[2] - if _llvm_patch.endswith('svn') - _llvm_patch = _llvm_patch.split('s')[0] +if with_llvm + if dep_llvm.found() + _llvm_version = dep_llvm.version().split('.') + # Development versions of LLVM have an 'svn' suffix, we don't want that for + # our version checks. + _llvm_patch = _llvm_version[2] + if _llvm_patch.endswith('svn') + _llvm_patch = _llvm_patch.split('s')[0] + endif + pre_args += [ + '-DHAVE_LLVM=0x0@0@@1@@2@'.format(_llvm_version[0], _llvm_version[1], _llvm_patch), + '-DMESA_LLVM_VERSION_PATCH=@0@'.format(_llvm_patch), + ] + else + if with_amd_vk or with_gallium_radeonsi + error('The following drivers requires LLVM: Radv, RadeonSI. One of these is enabled, but LLVM was not found.') + endif endif - pre_args += [ - '-DHAVE_LLVM=0x0@0@@1@@2@'.format(_llvm_version[0], _llvm_version[1], _llvm_patch), - '-DMESA_LLVM_VERSION_PATCH=@0@'.format(_llvm_patch), - ] +elif with_amd_vk or with_gallium_radeonsi + error('The following drivers requires LLVM: Radv, RadeonSI. One of these is enabled, but LLVM is disabled.') endif dep_glvnd = [] @@ -545,7 +604,10 @@ dep_selinux = [] # TODO: llvm-prefix and llvm-shared-libs -# TODO: unwind (llvm [radeon, gallivm] and gallium) +dep_unwind = dependency('libunwind', required : false) +if dep_unwind.found() + pre_args += '-DHAVE_LIBUNWIND' +endif # TODO: flags for opengl, gles, dri @@ -555,11 +617,6 @@ dep_selinux = [] # TODO: osmesa provider -# TODO: flags for xa, egl, gbm, nin, xvmc, vdpau, omx, va, opencl, -# gallium-tests, - -# TODO: gallium drivers - # TODO: symbol mangling # TODO: egl configuration @@ -576,63 +633,47 @@ else dep_wayland_server = [] endif +dep_x11 = [] +dep_xext = [] +dep_xdamage = [] +dep_xfixes = [] +dep_x11_xcb = [] +dep_xcb_glx = [] dep_xcb_dri2 = [] dep_xcb_dri3 = [] dep_dri2proto = [] dep_glproto = [] -dep_x11 = [] dep_xf86vm = [] +dep_xcb_dri3 = [] +dep_xcb_present = [] +dep_xcb_sync = [] +dep_xshmfence = [] if with_platform_x11 - if with_glx == 'xlib' - # TODO - error('TODO') - elif with_glx == 'gallium-xlib' - # TODO - error('TODO') - else - pre_args += '-DGLX_INDIRECT_RENDERING' - if with_glx_direct - pre_args += '-DGLX_DIRECT_RENDERING' - endif - if with_dri_platform == 'drm' - pre_args += '-DGLX_USE_DRM' - dep_dri2proto = dependency('dri2proto', version : '>= 2.8') - dep_x11 = [ - dependency('x11'), - dependency('xext'), - dependency('xdamage', version : '>= 1.1'), - dependency('xfixes'), - dependency('x11-xcb'), - dependency('xcb'), - dependency('xcb-glx', version : '>= 1.8.1'), - ] - - dep_xf86vm = dependency('xxf86vm', required : false) - endif - # TODO: XF86VIDMODE - endif - if with_glx != 'disabled' - dep_glproto = dependency('glproto', version : '>= 1.4.14') + if with_glx == 'dri' and with_dri_platform == 'drm' + dep_x11 = dependency('x11') + dep_xext = dependency('xext') + dep_xdamage = dependency('xdamage', version : '>= 1.1') + dep_xfixes = dependency('xfixes') + dep_xcb_glx = dependency('xcb-glx', version : '>= 1.8.1') + dep_xf86vm = dependency('xf86vm', required : false) endif if with_any_vk or (with_glx == 'dri' and with_dri_platform == 'drm') - dep_xcb_dri2 = [ - dependency('x11-xcb'), - dependency('xcb'), - dependency('xcb-dri2', version : '>= 1.8'), - dependency('xcb-xfixes'), - ] - pre_args += '-DHAVE_X11_PLATFORM' + dep_xcb = dependency('xcb') + dep_x11_xcb = dependency('x11-xcb') + dep_xcb_dri2 = dependency('xcb-dri2', version : '>= 1.8') + if with_dri3 pre_args += '-DHAVE_DRI3' - dep_xcb_dri3 = [ - dep_xcb_dri2, - dependency('xcb-dri3'), - dependency('xcb-present'), - dependency('xcb-sync'), - dependency('xshmfence', version : '>= 1.1'), - ] + dep_xcb_dri3 = dependency('xcb-dri3') + dep_xcb_present = dependency('xcb-present') + dep_xcb_sync = dependency('xcb-sync') + dep_xshmfence = dependency('xshmfence', version : '>= 1.1') endif endif + if with_glx != 'disabled' + dep_dri2proto = dependency('dri2proto', version : '>= 2.8') + dep_glproto = dependency('glproto', version : '>= 1.4.14') + endif endif # TODO: platforms for !vulkan @@ -641,8 +682,6 @@ endif # TODO: egl -# TODO: xa - # TODO: vallium G3DVL # TODO: nine @@ -650,9 +689,6 @@ endif # TODO: clover # TODO: egl sans x11 - -# TODO: xvmc - # TODO: gallium tests # TODO: various libdirs