Index: head/graphics/mesa-devel/Makefile =================================================================== --- head/graphics/mesa-devel/Makefile (revision 537514) +++ head/graphics/mesa-devel/Makefile (revision 537515) @@ -1,113 +1,148 @@ # $FreeBSD$ PORTNAME= mesa DISTVERSION= 20.1-branchpoint-1310 DISTVERSIONSUFFIX= -gaaec065f03e CATEGORIES= graphics PKGNAMESUFFIX= -devel PATCH_SITES= https://github.com/${GH_ACCOUNT}/${GH_PROJECT}/commit/ PATCHFILES+= ee5c7790fa93.patch:-p1 # https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/1598 PATCHFILES+= 9f52b5177728.patch:-p1 # https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/1598 PATCHFILES+= cefdea8105bf.patch:-p1 # https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/1598 PATCHFILES+= 55822330540d.patch:-p1 # https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/1598 PATCHFILES+= f6c7569ad9ea.patch:-p1 # https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/1598 PATCHFILES+= c7a2ab64144b.patch:-p1 # https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/1598 PATCHFILES+= f3b7aba7ed39.patch:-p1 # https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/1598 PATCHFILES+= 23df7d9971dd.patch:-p1 # https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/1598 PATCHFILES+= ec60ac47860a.patch:-p1 PATCHFILES+= 807ae077ab19.patch:-p1 # https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/3568 PATCHFILES+= 1b10b42fe65e.patch:-p1 # https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/1619 PATCHFILES+= 9291544ca0bd.patch:-p1 PATCHFILES+= 700efacda59c.patch:-p1 PATCHFILES+= 227ebbd9e837.patch:-p1 PATCHFILES+= de60a36d5836.patch:-p1 PATCHFILES+= 0a500a8f4648.patch:-p1 PATCHFILES+= 15057d74fdb9.patch:-p1 MAINTAINER= jbeich@FreeBSD.org COMMENT= Bleeding edge Mesa drivers (OpenGL, Vulkan) LICENSE= MIT -ONLY_FOR_ARCHS= amd64 i386 +ONLY_FOR_ARCHS= aarch64 amd64 i386 powerpc64 ONLY_FOR_ARCHS_REASON= Limited scope: no old drivers and no software rendering. \ See also https://mesamatrix.net/ -BROKEN_DragonFly= requires making Vulkan support conditional -BUILD_DEPENDS= glslangValidator:devel/glslang \ - ${PYTHON_PKGNAMEPREFIX}mako>0:textproc/py-mako@${PY_FLAVOR} -LIB_DEPENDS= libLLVM-${LLVM_DEFAULT:C/^([6-9])0/\1/:S/-devel/11/}.so:devel/llvm${LLVM_DEFAULT} \ - libdrm.so:graphics/libdrm \ +BUILD_DEPENDS= ${PYTHON_PKGNAMEPREFIX}mako>0:textproc/py-mako@${PY_FLAVOR} +LIB_DEPENDS= libdrm.so:graphics/libdrm \ libexpat.so:textproc/expat2 +.if !exists(/usr/lib/libelf.so) +# DragonFly doesn't install it yet +LIB_DEPENDS+= libelf.so:devel/libelf +.endif USES= bison compiler:c++11-lib meson pkgconfig python:3.6+,build shebangfix USE_GITHUB= yes GH_ACCOUNT= mesa3d USE_LDCONFIG= yes -BINARY_ALIAS= llvm-config=llvm-config${LLVM_DEFAULT} python=${PYTHON_CMD} +BINARY_ALIAS= python=${PYTHON_CMD} SHEBANG_FILES= src/vulkan/overlay-layer/${PORTNAME}-overlay-control.py PLATFORMS= ${PORT_OPTIONS:MX11:tl} ${PORT_OPTIONS:MWAYLAND:tl} drm surfaceless -MESON_ARGS= -Ddri-drivers=i965 \ - -Dgallium-drivers=iris,r600,radeonsi \ - -Dgallium-omx=disabled \ +MESON_ARGS= -Dgallium-omx=disabled \ -Dgallium-opencl=disabled \ -Dgallium-xa=false \ -Dgallium-xvmc=false \ -Dplatforms=${PLATFORMS:ts,} \ - -Dvulkan-device-select-layer=true \ - -Dvulkan-overlay-layer=true \ ${PKGNAMESUFFIX:S/^/-Degl-lib-suffix=/} \ ${NULL} SUB_FILES= libmap.conf SUB_LIST= PKGNAMESUFFIX=${PKGNAMESUFFIX} PLIST_SUB= ARCH=${ARCH:S/amd/x86_/} PKGNAMESUFFIX=${PKGNAMESUFFIX} -.if ${/usr/bin/ld:L:tA} != /usr/bin/ld.lld +.if exists(/usr/bin/ld.lld) && ${/usr/bin/ld:L:tA} != /usr/bin/ld.lld # --build-id isn't supported by old GNU ld.bfd in base LDFLAGS+= -fuse-ld=lld .endif -OPTIONS_DEFINE= LIBUNWIND VAAPI VDPAU WAYLAND X11 ZSTD -OPTIONS_DEFAULT= LIBUNWIND VAAPI VDPAU WAYLAND X11 ZSTD +OPTIONS_DEFINE= ${OPTIONS_MULTI} LIBUNWIND LLVM VAAPI VDPAU WAYLAND X11 ZSTD +OPTIONS_DEFAULT= ${OPTIONS_MULTI} LIBUNWIND LLVM VAAPI VDPAU WAYLAND X11 ZSTD +OPTIONS_MULTI= DRI GALLIUM VULKAN +OPTIONS_MULTI_DRI= i965 +OPTIONS_MULTI_GALLIUM= iris r600 radeonsi +OPTIONS_MULTI_VULKAN= anv radv +OPTIONS_EXCLUDE_DragonFly= LIBUNWIND anv +OPTIONS_EXCLUDE+= ${ARCH:Namd64:Ni386:C/.+/anv i965 iris/} +OPTIONS_EXCLUDE+= ${ARCH:Naarch64:Namd64:Ni386:C/.+/LIBUNWIND/} OPTIONS_SUB= yes +# Convert options to -D-drivers= +.for i in ${OPTIONS_MULTI} +MESON_ARGS+= -D${i:tl}-drivers=${${i}_DRIVERS:ts,} +. for j in ${OPTIONS_MULTI_${i}} +OPTIONS_DEFAULT+= ${j} +${j}_VARS+= ${i}_DRIVERS+=${j:S/anv/intel/:S/radv/amd/} +. endfor +.endfor + +DRI_DESC= Classic OpenGL drivers +i965_DESC= GMA 3000 (Gen4) and newer + +GALLIUM_DESC= Unified OpenGL drivers +iris_DESC= Broadwell and newer +r600_DESC= R600, R700, Evergreen, Northern Islands +radeonsi_DESC= Southern Islands and newer + LIBUNWIND_DESC= Use libunwind for stacktraces LIBUNWIND_LIB_DEPENDS= libunwind.so:devel/libunwind LIBUNWIND_MESON_TRUE= libunwind +LLVM_DESC= Build with LLVM support +LLVM_LIB_DEPENDS= libLLVM-${LLVM_DEFAULT:C/^([6-9])0/\1/:S/-devel/11/}.so:devel/llvm${LLVM_DEFAULT} +LLVM_MESON_TRUE= llvm +LLVM_BINARY_ALIAS= llvm-config=llvm-config${LLVM_DEFAULT} +.for i in r600 radeonsi radv +${i}_IMPLIES+= LLVM +.endfor + VAAPI_BUILD_DEPENDS= libva>0:multimedia/libva VAAPI_MESON_TRUE= gallium-va VDPAU_BUILD_DEPENDS= libvdpau>0:multimedia/libvdpau VDPAU_MESON_TRUE= gallium-vdpau + +VULKAN_DESC= Vulkan drivers and layers +VULKAN_BUILD_DEPENDS= glslangValidator:devel/glslang +VULKAN_MESON_TRUE= vulkan-device-select-layer vulkan-overlay-layer +anv_DESC= Haswell and newer +radv_DESC= Southern Islands and newer WAYLAND_BUILD_DEPENDS= wayland-protocols>0:graphics/wayland-protocols WAYLAND_LIB_DEPENDS= libwayland-server.so:graphics/wayland X11_USES= xorg X11_USE= XORG=x11,xcb,xdamage,xext,xfixes,xorgproto,xrandr,xshmfence,xxf86vm X11_MESON_OFF= -Dglx=disabled ZSTD_DESC= Use ZSTD for shader cache ZSTD_LIB_DEPENDS= libzstd.so:archivers/zstd ZSTD_MESON_TRUE= zstd post-patch: # Extract (snapshot) version from the port instead of empty string @${REINPLACE_CMD} '/MESA_GIT_SHA1/s/""/" (git-${DISTVERSIONSUFFIX:C/.*-g//})"/' \ ${WRKSRC}/bin/git_sha1_gen.py .if defined(PKGNAMESUFFIX) @${MV} ${WRKSRC}/src/egl/main/50_${PORTNAME}.json \ ${WRKSRC}/src/egl/main/50_${PKGBASE}.json @${MV} ${WRKSRC}/src/util/00-${PORTNAME}-defaults.conf \ ${WRKSRC}/src/util/00-${PKGBASE}-defaults.conf .endif post-install: .if defined(PKGNAMESUFFIX) @${INSTALL_DATA} ${WRKDIR}/libmap.conf \ ${STAGEDIR}${PREFIX}/etc/libmap.d/${PKGBASE}.conf.sample .endif .include Index: head/graphics/mesa-devel/files/libmap.conf.in =================================================================== --- head/graphics/mesa-devel/files/libmap.conf.in (revision 537514) +++ head/graphics/mesa-devel/files/libmap.conf.in (revision 537515) @@ -1,26 +1,25 @@ # EGL/GLX built with -Dglvnd=false libEGL.so.1 libEGL%%PKGNAMESUFFIX%%.so.1 libGL.so.1 libGL%%PKGNAMESUFFIX%%.so.1 libGLESv1_CM.so.1 libGLESv1_CM%%PKGNAMESUFFIX%%.so.1 libGLESv2.so.2 libGLESv2%%PKGNAMESUFFIX%%.so.2 # EGL/GLX built with -Dglvnd=true # Xorg sets GLX_EXT_libglvnd to "mesa" by default libEGL_mesa.so.0 libEGL_mesa%%PKGNAMESUFFIX%%.so.0 libGLX_mesa.so.0 libGLX_mesa%%PKGNAMESUFFIX%%.so.0 # Fallback if GLX_EXT_libglvnd is missing or vendor library doesn't exist libGLX_indirect.so.0 libGLX_mesa%%PKGNAMESUFFIX%%.so.0 # GBM clients like eglkms and wlroots fail otherwise libgbm.so.1 libgbm%%PKGNAMESUFFIX%%.so.1 -# Avoid different versions of the same driver showing up as multiple GPUs -%%PREFIX%%/lib/libvulkan_intel.so libvulkan_intel%%PKGNAMESUFFIX%%.so -%%PREFIX%%/lib/libvulkan_radeon.so libvulkan_radeon%%PKGNAMESUFFIX%%.so +%%VULKAN%%# Avoid different versions of the same driver showing up as multiple GPUs +%%anv%%%%PREFIX%%/lib/libvulkan_intel.so libvulkan_intel%%PKGNAMESUFFIX%%.so +%%radv%%%%PREFIX%%/lib/libvulkan_radeon.so libvulkan_radeon%%PKGNAMESUFFIX%%.so -# VAAPI/VDPAU -%%PREFIX%%/lib/dri/r600_drv_video.so %%PREFIX%%/lib/dri%%PKGNAMESUFFIX%%/r600_drv_video.so -%%PREFIX%%/lib/dri/radeonsi_drv_video.so %%PREFIX%%/lib/dri%%PKGNAMESUFFIX%%/radeonsi_drv_video.so -%%PREFIX%%/lib/vdpau/libvdpau_r600.so.1 %%PREFIX%%/lib/vdpau%%PKGNAMESUFFIX%%/libvdpau_r600.so.1 -%%PREFIX%%/lib/vdpau/libvdpau_radeonsi.so.1 %%PREFIX%%/lib/vdpau%%PKGNAMESUFFIX%%/libvdpau_radeonsi.so.1 +%%VAAPI%%%%r600%%%%PREFIX%%/lib/dri/r600_drv_video.so %%PREFIX%%/lib/dri%%PKGNAMESUFFIX%%/r600_drv_video.so +%%VAAPI%%%%radeonsi%%%%PREFIX%%/lib/dri/radeonsi_drv_video.so %%PREFIX%%/lib/dri%%PKGNAMESUFFIX%%/radeonsi_drv_video.so +%%VDPAU%%%%r600%%%%PREFIX%%/lib/vdpau/libvdpau_r600.so.1 %%PREFIX%%/lib/vdpau%%PKGNAMESUFFIX%%/libvdpau_r600.so.1 +%%VDPAU%%%%radeonsi%%%%PREFIX%%/lib/vdpau/libvdpau_radeonsi.so.1 %%PREFIX%%/lib/vdpau%%PKGNAMESUFFIX%%/libvdpau_radeonsi.so.1 Index: head/graphics/mesa-devel/pkg-plist =================================================================== --- head/graphics/mesa-devel/pkg-plist (revision 537514) +++ head/graphics/mesa-devel/pkg-plist (revision 537515) @@ -1,75 +1,75 @@ -bin/mesa-overlay-control.py +%%VULKAN%%bin/mesa-overlay-control.py @sample etc/libmap.d/mesa%%PKGNAMESUFFIX%%.conf.sample @comment include/EGL/egl.h @comment include/EGL/eglext.h @comment include/EGL/eglextchromium.h @comment include/EGL/eglmesaext.h @comment include/EGL/eglplatform.h @comment include/GL/gl.h @comment include/GL/glcorearb.h @comment include/GL/glext.h @comment include/GL/glx.h @comment include/GL/glxext.h @comment include/GL/internal/dri_interface.h @comment include/GLES/egl.h @comment include/GLES/gl.h @comment include/GLES/glext.h @comment include/GLES/glplatform.h @comment include/GLES2/gl2.h @comment include/GLES2/gl2ext.h @comment include/GLES2/gl2platform.h @comment include/GLES3/gl3.h @comment include/GLES3/gl31.h @comment include/GLES3/gl32.h @comment include/GLES3/gl3ext.h @comment include/GLES3/gl3platform.h @comment include/KHR/khrplatform.h @comment include/gbm.h -@comment include/vulkan/vulkan_intel.h -lib/dri%%PKGNAMESUFFIX%%/i965_dri.so -lib/dri%%PKGNAMESUFFIX%%/iris_dri.so -lib/dri%%PKGNAMESUFFIX%%/r600_dri.so -lib/dri%%PKGNAMESUFFIX%%/radeonsi_dri.so -%%VAAPI%%lib/dri%%PKGNAMESUFFIX%%/r600_drv_video.so -%%VAAPI%%lib/dri%%PKGNAMESUFFIX%%/radeonsi_drv_video.so +%%anv%%@comment include/vulkan/vulkan_intel.h +%%i965%%lib/dri%%PKGNAMESUFFIX%%/i965_dri.so +%%iris%%lib/dri%%PKGNAMESUFFIX%%/iris_dri.so +%%r600%%lib/dri%%PKGNAMESUFFIX%%/r600_dri.so +%%radeonsi%%lib/dri%%PKGNAMESUFFIX%%/radeonsi_dri.so +%%VAAPI%%%%r600%%lib/dri%%PKGNAMESUFFIX%%/r600_drv_video.so +%%VAAPI%%%%radeonsi%%lib/dri%%PKGNAMESUFFIX%%/radeonsi_drv_video.so @comment lib/libEGL%%PKGNAMESUFFIX%%.so lib/libEGL%%PKGNAMESUFFIX%%.so.1 lib/libEGL%%PKGNAMESUFFIX%%.so.1.0.0 %%X11%%@comment lib/libGL%%PKGNAMESUFFIX%%.so %%X11%%lib/libGL%%PKGNAMESUFFIX%%.so.1 %%X11%%lib/libGL%%PKGNAMESUFFIX%%.so.1.2.0 @comment lib/libGLESv1_CM%%PKGNAMESUFFIX%%.so lib/libGLESv1_CM%%PKGNAMESUFFIX%%.so.1 lib/libGLESv1_CM%%PKGNAMESUFFIX%%.so.1.1.0 @comment lib/libGLESv2%%PKGNAMESUFFIX%%.so lib/libGLESv2%%PKGNAMESUFFIX%%.so.2 lib/libGLESv2%%PKGNAMESUFFIX%%.so.2.0.0 -lib/libVkLayer_MESA_device_select.so -lib/libVkLayer_MESA_overlay.so +%%VULKAN%%lib/libVkLayer_MESA_device_select.so +%%VULKAN%%lib/libVkLayer_MESA_overlay.so @comment lib/libgbm%%PKGNAMESUFFIX%%.so lib/libgbm%%PKGNAMESUFFIX%%.so.1 lib/libgbm%%PKGNAMESUFFIX%%.so.1.0.0 @comment lib/libglapi%%PKGNAMESUFFIX%%.so lib/libglapi%%PKGNAMESUFFIX%%.so.0 lib/libglapi%%PKGNAMESUFFIX%%.so.0.0.0 -lib/libvulkan_intel%%PKGNAMESUFFIX%%.so -lib/libvulkan_radeon%%PKGNAMESUFFIX%%.so -%%VDPAU%%lib/vdpau%%PKGNAMESUFFIX%%/libvdpau_r600.so -%%VDPAU%%lib/vdpau%%PKGNAMESUFFIX%%/libvdpau_r600.so.1 -%%VDPAU%%lib/vdpau%%PKGNAMESUFFIX%%/libvdpau_r600.so.1.0 -%%VDPAU%%lib/vdpau%%PKGNAMESUFFIX%%/libvdpau_r600.so.1.0.0 -%%VDPAU%%lib/vdpau%%PKGNAMESUFFIX%%/libvdpau_radeonsi.so -%%VDPAU%%lib/vdpau%%PKGNAMESUFFIX%%/libvdpau_radeonsi.so.1 -%%VDPAU%%lib/vdpau%%PKGNAMESUFFIX%%/libvdpau_radeonsi.so.1.0 -%%VDPAU%%lib/vdpau%%PKGNAMESUFFIX%%/libvdpau_radeonsi.so.1.0.0 +%%anv%%lib/libvulkan_intel%%PKGNAMESUFFIX%%.so +%%radv%%lib/libvulkan_radeon%%PKGNAMESUFFIX%%.so +%%VDPAU%%%%r600%%lib/vdpau%%PKGNAMESUFFIX%%/libvdpau_r600.so +%%VDPAU%%%%r600%%lib/vdpau%%PKGNAMESUFFIX%%/libvdpau_r600.so.1 +%%VDPAU%%%%r600%%lib/vdpau%%PKGNAMESUFFIX%%/libvdpau_r600.so.1.0 +%%VDPAU%%%%r600%%lib/vdpau%%PKGNAMESUFFIX%%/libvdpau_r600.so.1.0.0 +%%VDPAU%%%%radeonsi%%lib/vdpau%%PKGNAMESUFFIX%%/libvdpau_radeonsi.so +%%VDPAU%%%%radeonsi%%lib/vdpau%%PKGNAMESUFFIX%%/libvdpau_radeonsi.so.1 +%%VDPAU%%%%radeonsi%%lib/vdpau%%PKGNAMESUFFIX%%/libvdpau_radeonsi.so.1.0 +%%VDPAU%%%%radeonsi%%lib/vdpau%%PKGNAMESUFFIX%%/libvdpau_radeonsi.so.1.0.0 @comment libdata/pkgconfig/dri.pc @comment libdata/pkgconfig/egl.pc @comment libdata/pkgconfig/gbm.pc @comment libdata/pkgconfig/gl.pc @comment libdata/pkgconfig/glesv1_cm.pc @comment libdata/pkgconfig/glesv2.pc share/drirc.d/00-mesa%%PKGNAMESUFFIX%%-defaults.conf -share/vulkan/explicit_layer.d/VkLayer_MESA_overlay.json -@comment share/vulkan/icd.d/intel_icd.%%ARCH%%.json -@comment share/vulkan/icd.d/radeon_icd.%%ARCH%%.json -share/vulkan/implicit_layer.d/VkLayer_MESA_device_select.json +%%VULKAN%%share/vulkan/explicit_layer.d/VkLayer_MESA_overlay.json +%%anv%%@comment share/vulkan/icd.d/intel_icd.%%ARCH%%.json +%%radv%%@comment share/vulkan/icd.d/radeon_icd.%%ARCH%%.json +%%VULKAN%%share/vulkan/implicit_layer.d/VkLayer_MESA_device_select.json