diff options
| author | Otavio Salvador <otavio@ossystems.com.br> | 2024-10-25 07:17:39 -0300 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2024-10-25 07:17:39 -0300 |
| commit | 074d8c221526a9e76d28ee98a3c9e4ce372b13c7 (patch) | |
| tree | 4c2c21600d12c0a2c1bf40c3f8ecd9b87e76e235 | |
| parent | fdca219fecba823b60b7fd84d14e72f1a070c811 (diff) | |
| parent | ff9e2a169e43ab2917d89294a19b2d0624936627 (diff) | |
| download | meta-freescale-074d8c221526a9e76d28ee98a3c9e4ce372b13c7.tar.gz | |
Merge pull request #1998 from MaxKrummenacher/master
Add GPU support for i.MX95
9 files changed, 152 insertions, 2 deletions
diff --git a/conf/machine/imx95-19x19-verdin.conf b/conf/machine/imx95-19x19-verdin.conf index a271388c3..d03d69139 100644 --- a/conf/machine/imx95-19x19-verdin.conf +++ b/conf/machine/imx95-19x19-verdin.conf | |||
| @@ -1,7 +1,7 @@ | |||
| 1 | #@TYPE: Machine | 1 | #@TYPE: Machine |
| 2 | #@NAME: Toradex i.MX 95 19x19 Verdin board | 2 | #@NAME: Toradex i.MX 95 19x19 Verdin Evaluation Kit |
| 3 | #@SOC: i.MX95 | 3 | #@SOC: i.MX95 |
| 4 | #@DESCRIPTION: Machine configuration for Toradex i.MX 95 19x19 Verdin board | 4 | #@DESCRIPTION: Machine configuration for Toradex i.MX 95 19x19 Verdin Evaluation Ki |
| 5 | #@MAINTAINER: Flora Hu <flora.hu@nxp.com> | 5 | #@MAINTAINER: Flora Hu <flora.hu@nxp.com> |
| 6 | 6 | ||
| 7 | MACHINEOVERRIDES =. "mx95:" | 7 | MACHINEOVERRIDES =. "mx95:" |
diff --git a/conf/machine/include/imx-base.inc b/conf/machine/include/imx-base.inc index 9d06b4649..b4f853888 100644 --- a/conf/machine/include/imx-base.inc +++ b/conf/machine/include/imx-base.inc | |||
| @@ -574,6 +574,16 @@ PREFERRED_PROVIDER_opencl-headers:imxgpu ?= "imx-gpu-viv" | |||
| 574 | PREFERRED_PROVIDER_opencl-icd-loader:imxgpu ?= "imx-gpu-viv" | 574 | PREFERRED_PROVIDER_opencl-icd-loader:imxgpu ?= "imx-gpu-viv" |
| 575 | PREFERRED_PROVIDER_virtual/opencl-icd:imxgpu ?= "imx-gpu-viv" | 575 | PREFERRED_PROVIDER_virtual/opencl-icd:imxgpu ?= "imx-gpu-viv" |
| 576 | 576 | ||
| 577 | PREFERRED_PROVIDER_virtual/egl:mx95-nxp-bsp ?= "mali-imx" | ||
| 578 | PREFERRED_PROVIDER_virtual/libgles1:mx95-nxp-bsp ?= "mali-imx" | ||
| 579 | PREFERRED_PROVIDER_virtual/libgles2:mx95-nxp-bsp ?= "mali-imx" | ||
| 580 | PREFERRED_PROVIDER_virtual/libgles3:mx95-nxp-bsp ?= "mali-imx" | ||
| 581 | PREFERRED_PROVIDER_opencl-clhpp:mx95-nxp-bsp ?= "opencl-clhpp" | ||
| 582 | PREFERRED_PROVIDER_opencl-headers:mx95-nxp-bsp ?= "opencl-headers" | ||
| 583 | # install libmali-opencl-icd package as the loaders backend | ||
| 584 | PREFERRED_PROVIDER_opencl-icd-loader:mx95-nxp-bsp ?= "opencl-icd-loader" | ||
| 585 | PREFERRED_PROVIDER_virtual/opencl-icd:mx95-nxp-bsp ?= "opencl-icd-loader" | ||
| 586 | |||
| 577 | PREFERRED_VERSION_weston:imx-nxp-bsp ??= "12.0.4.imx" | 587 | PREFERRED_VERSION_weston:imx-nxp-bsp ??= "12.0.4.imx" |
| 578 | # i.MX 6 & 7 stay on weston 10.0 for fbdev | 588 | # i.MX 6 & 7 stay on weston 10.0 for fbdev |
| 579 | PREFERRED_VERSION_weston:mx6-nxp-bsp ??= "10.0.5.imx" | 589 | PREFERRED_VERSION_weston:mx6-nxp-bsp ??= "10.0.5.imx" |
diff --git a/dynamic-layers/openembedded-layer/recipes-benchmark/glmark2/glmark2_%.bbappend b/dynamic-layers/openembedded-layer/recipes-benchmark/glmark2/glmark2_%.bbappend index 4cfa51ea9..a5d3c2e2c 100644 --- a/dynamic-layers/openembedded-layer/recipes-benchmark/glmark2/glmark2_%.bbappend +++ b/dynamic-layers/openembedded-layer/recipes-benchmark/glmark2/glmark2_%.bbappend | |||
| @@ -1,4 +1,5 @@ | |||
| 1 | # Only _mx8 machine do provide virtual/libgbm required for any drm* flavour | 1 | # Only _mx8 machine do provide virtual/libgbm required for any drm* flavour |
| 2 | DRM-REMOVE:imxgpu = "drm-gl drm-gles2" | 2 | DRM-REMOVE:imxgpu = "drm-gl drm-gles2" |
| 3 | DRM-REMOVE:imxgpu:mx8-nxp-bsp = "" | 3 | DRM-REMOVE:imxgpu:mx8-nxp-bsp = "" |
| 4 | DRM-REMOVE:imxgpu:mx95-nxp-bsp = "" | ||
| 4 | PACKAGECONFIG:remove = "${DRM-REMOVE}" | 5 | PACKAGECONFIG:remove = "${DRM-REMOVE}" |
diff --git a/dynamic-layers/qt5-layer/recipes-qt/qt5/qtbase_%.bbappend b/dynamic-layers/qt5-layer/recipes-qt/qt5/qtbase_%.bbappend index 7401a5669..e450e568e 100644 --- a/dynamic-layers/qt5-layer/recipes-qt/qt5/qtbase_%.bbappend +++ b/dynamic-layers/qt5-layer/recipes-qt/qt5/qtbase_%.bbappend | |||
| @@ -12,6 +12,7 @@ SRC_URI:append:imxgpu = " \ | |||
| 12 | 12 | ||
| 13 | PACKAGECONFIG_GL_IMX_GPU = "" | 13 | PACKAGECONFIG_GL_IMX_GPU = "" |
| 14 | PACKAGECONFIG_GL_IMX_GPU:mx8-nxp-bsp = "gbm kms" | 14 | PACKAGECONFIG_GL_IMX_GPU:mx8-nxp-bsp = "gbm kms" |
| 15 | PACKAGECONFIG_GL_IMX_GPU:mx95-nxp-bsp = "gbm kms" | ||
| 15 | 16 | ||
| 16 | PACKAGECONFIG_GL:imxpxp = "gles2" | 17 | PACKAGECONFIG_GL:imxpxp = "gles2" |
| 17 | PACKAGECONFIG_GL:imxgpu2d = "${@bb.utils.contains('DISTRO_FEATURES', 'x11', ' gl', '', d)} \ | 18 | PACKAGECONFIG_GL:imxgpu2d = "${@bb.utils.contains('DISTRO_FEATURES', 'x11', ' gl', '', d)} \ |
| @@ -31,6 +32,7 @@ PACKAGECONFIG += "${PACKAGECONFIG_PLATFORM}" | |||
| 31 | 32 | ||
| 32 | PACKAGECONFIG_VULKAN_IMX_GPU = "" | 33 | PACKAGECONFIG_VULKAN_IMX_GPU = "" |
| 33 | PACKAGECONFIG_VULKAN_IMX_GPU:mx8-nxp-bsp = "vulkan" | 34 | PACKAGECONFIG_VULKAN_IMX_GPU:mx8-nxp-bsp = "vulkan" |
| 35 | PACKAGECONFIG_VULKAN_IMX_GPU:mx9-nxp-bsp = "vulkan" | ||
| 34 | PACKAGECONFIG_VULKAN_IMX_GPU:mx8mm-nxp-bsp = "" | 36 | PACKAGECONFIG_VULKAN_IMX_GPU:mx8mm-nxp-bsp = "" |
| 35 | PACKAGECONFIG_VULKAN = "" | 37 | PACKAGECONFIG_VULKAN = "" |
| 36 | PACKAGECONFIG_VULKAN:imxgpu = "${PACKAGECONFIG_VULKAN_IMX_GPU}" | 38 | PACKAGECONFIG_VULKAN:imxgpu = "${PACKAGECONFIG_VULKAN_IMX_GPU}" |
diff --git a/dynamic-layers/qt5-layer/recipes-qt/qt5/qtwayland_%.bbappend b/dynamic-layers/qt5-layer/recipes-qt/qt5/qtwayland_%.bbappend index a97b765f1..659a7cc0a 100644 --- a/dynamic-layers/qt5-layer/recipes-qt/qt5/qtwayland_%.bbappend +++ b/dynamic-layers/qt5-layer/recipes-qt/qt5/qtwayland_%.bbappend | |||
| @@ -6,3 +6,4 @@ PACKAGECONFIG:remove:mx7-nxp-bsp = "xcomposite-egl xcomposite-glx" | |||
| 6 | 6 | ||
| 7 | # i.MX8 does never provide native x11, so required dependencies are not met | 7 | # i.MX8 does never provide native x11, so required dependencies are not met |
| 8 | PACKAGECONFIG:remove:mx8-nxp-bsp = "xcomposite-egl xcomposite-glx" | 8 | PACKAGECONFIG:remove:mx8-nxp-bsp = "xcomposite-egl xcomposite-glx" |
| 9 | PACKAGECONFIG:remove:mx95-nxp-bsp = "xcomposite-egl xcomposite-glx" | ||
diff --git a/dynamic-layers/qt6-layer/recipes-qt/qt6/qtbase_%.bbappend b/dynamic-layers/qt6-layer/recipes-qt/qt6/qtbase_%.bbappend index 1c51fc09d..b12499666 100644 --- a/dynamic-layers/qt6-layer/recipes-qt/qt6/qtbase_%.bbappend +++ b/dynamic-layers/qt6-layer/recipes-qt/qt6/qtbase_%.bbappend | |||
| @@ -14,6 +14,8 @@ PACKAGECONFIG_GRAPHICS:imxgpu3d = " \ | |||
| 14 | PACKAGECONFIG_GRAPHICS_IMX_GPU = "" | 14 | PACKAGECONFIG_GRAPHICS_IMX_GPU = "" |
| 15 | PACKAGECONFIG_GRAPHICS_IMX_GPU:mx8-nxp-bsp = " \ | 15 | PACKAGECONFIG_GRAPHICS_IMX_GPU:mx8-nxp-bsp = " \ |
| 16 | gbm kms" | 16 | gbm kms" |
| 17 | PACKAGECONFIG_GRAPHICS_IMX_GPU:mx95-nxp-bsp = " \ | ||
| 18 | gbm kms" | ||
| 17 | 19 | ||
| 18 | PACKAGECONFIG_GRAPHICS:use-mainline-bsp ?= " \ | 20 | PACKAGECONFIG_GRAPHICS:use-mainline-bsp ?= " \ |
| 19 | gles2 gbm kms" | 21 | gles2 gbm kms" |
| @@ -51,4 +53,5 @@ PACKAGECONFIG_VULKAN:imxgpu = " \ | |||
| 51 | ${PACKAGECONFIG_VULKAN_IMX_GPU}" | 53 | ${PACKAGECONFIG_VULKAN_IMX_GPU}" |
| 52 | PACKAGECONFIG_VULKAN_IMX_GPU = "" | 54 | PACKAGECONFIG_VULKAN_IMX_GPU = "" |
| 53 | PACKAGECONFIG_VULKAN_IMX_GPU:mx8-nxp-bsp = "vulkan" | 55 | PACKAGECONFIG_VULKAN_IMX_GPU:mx8-nxp-bsp = "vulkan" |
| 56 | PACKAGECONFIG_VULKAN_IMX_GPU:mx95-nxp-bsp = "vulkan" | ||
| 54 | PACKAGECONFIG_VULKAN_IMX_GPU:mx8mm-nxp-bsp = "" | 57 | PACKAGECONFIG_VULKAN_IMX_GPU:mx8mm-nxp-bsp = "" |
diff --git a/dynamic-layers/qt6-layer/recipes-qt/qt6/qtwayland_%.bbappend b/dynamic-layers/qt6-layer/recipes-qt/qt6/qtwayland_%.bbappend index ca011758b..f2b0b8025 100644 --- a/dynamic-layers/qt6-layer/recipes-qt/qt6/qtwayland_%.bbappend +++ b/dynamic-layers/qt6-layer/recipes-qt/qt6/qtwayland_%.bbappend | |||
| @@ -4,3 +4,4 @@ PACKAGECONFIG:remove:use-mainline-bsp = "xcomposite-glx" | |||
| 4 | PACKAGECONFIG:remove:mx6-nxp-bsp = "xcomposite-egl xcomposite-glx" | 4 | PACKAGECONFIG:remove:mx6-nxp-bsp = "xcomposite-egl xcomposite-glx" |
| 5 | PACKAGECONFIG:remove:mx7-nxp-bsp = "xcomposite-egl xcomposite-glx" | 5 | PACKAGECONFIG:remove:mx7-nxp-bsp = "xcomposite-egl xcomposite-glx" |
| 6 | PACKAGECONFIG:remove:mx8-nxp-bsp = "xcomposite-egl xcomposite-glx" | 6 | PACKAGECONFIG:remove:mx8-nxp-bsp = "xcomposite-egl xcomposite-glx" |
| 7 | PACKAGECONFIG:remove:mx95-nxp-bsp = "xcomposite-egl xcomposite-glx" | ||
diff --git a/recipes-graphics/mali/mali-imx.inc b/recipes-graphics/mali/mali-imx.inc new file mode 100644 index 000000000..e4fafeb0b --- /dev/null +++ b/recipes-graphics/mali/mali-imx.inc | |||
| @@ -0,0 +1,107 @@ | |||
| 1 | SUMMARY = "Graphics libraries and driver for i.MX Mali GPU" | ||
| 2 | SECTION = "libs" | ||
| 3 | DEPENDS = " \ | ||
| 4 | libdrm \ | ||
| 5 | vulkan-loader \ | ||
| 6 | wayland \ | ||
| 7 | wayland-protocols" | ||
| 8 | PROVIDES = " \ | ||
| 9 | virtual/egl \ | ||
| 10 | virtual/libgbm \ | ||
| 11 | virtual/libgles1 \ | ||
| 12 | virtual/libgles2 \ | ||
| 13 | virtual/libgles3" | ||
| 14 | |||
| 15 | # The packaged binaries have been stripped of debug info, so disable | ||
| 16 | # operations accordingly. | ||
| 17 | INHIBIT_PACKAGE_DEBUG_SPLIT = "1" | ||
| 18 | INHIBIT_PACKAGE_STRIP = "1" | ||
| 19 | INHIBIT_SYSROOT_STRIP = "1" | ||
| 20 | |||
| 21 | PACKAGES =+ " \ | ||
| 22 | ${PN}-libegl ${PN}-libegl-dev \ | ||
| 23 | ${PN}-libgbm ${PN}-libgbm-dev \ | ||
| 24 | ${PN}-libgles1 ${PN}-libgles1-dev \ | ||
| 25 | ${PN}-libgles2 ${PN}-libgles2-dev \ | ||
| 26 | ${PN}-libgles3 ${PN}-libgles3-dev \ | ||
| 27 | ${PN}-libvulkan \ | ||
| 28 | ${PN}-opencl-icd ${PN}-opencl-icd-dev" | ||
| 29 | |||
| 30 | # Since libmali.so is loaded by dlopen, include it in the main package | ||
| 31 | FILES:${PN} += " \ | ||
| 32 | ${libdir}/libmali.so \ | ||
| 33 | ${nonarch_base_libdir}/firmware" | ||
| 34 | FILES_SOLIBSDEV = "" | ||
| 35 | INSANE_SKIP:${PN} = "dev-so" | ||
| 36 | FILES:${PN}-libegl = " \ | ||
| 37 | ${libdir}/libEGL${SOLIBS}" | ||
| 38 | FILES:${PN}-libgbm = " \ | ||
| 39 | ${libdir}/libgbm${SOLIBS}" | ||
| 40 | FILES:${PN}-libgles1 = " \ | ||
| 41 | ${libdir}/libGLESv1_CM${SOLIBS}" | ||
| 42 | FILES:${PN}-libgles2 = " \ | ||
| 43 | ${libdir}/libGLESv2${SOLIBS}" | ||
| 44 | FILES:${PN}-opencl-icd = " \ | ||
| 45 | ${sysconfdir}/OpenCL" | ||
| 46 | FILES:${PN}-libvulkan = " \ | ||
| 47 | ${sysconfdir}/vulkan" | ||
| 48 | |||
| 49 | FILES:${PN}-dev = " \ | ||
| 50 | ${bindir}/malisc" | ||
| 51 | FILES:${PN}-libegl-dev = " \ | ||
| 52 | ${includedir}/EGL \ | ||
| 53 | ${includedir}/KHR \ | ||
| 54 | ${libdir}/libEGL${SOLIBSDEV} \ | ||
| 55 | ${libdir}/pkgconfig/egl.pc" | ||
| 56 | FILES:${PN}-libgbm-dev = " \ | ||
| 57 | ${includedir}/gbm.h \ | ||
| 58 | ${libdir}/libgbm${SOLIBSDEV} \ | ||
| 59 | ${libdir}/pkgconfig/gbm.pc" | ||
| 60 | |||
| 61 | # Consolidate GLES dev packages | ||
| 62 | PACKAGES =+ "${PN}-libgles-dev" | ||
| 63 | FILES:${PN}-libgles-dev = " \ | ||
| 64 | ${includedir}/GLES* \ | ||
| 65 | ${libdir}/libGLES*${SOLIBSDEV} \ | ||
| 66 | ${libdir}/pkgconfig/gles*.pc" | ||
| 67 | DEBIAN_NOAUTONAME:${PN}-libgles-dev = "1" | ||
| 68 | RREPLACES:${PN}-libgles-dev = "libgles-dev" | ||
| 69 | RPROVIDES:${PN}-libgles-dev = "libgles-dev" | ||
| 70 | RCONFLICTS:${PN}-libgles-dev = "libgles-dev" | ||
| 71 | ALLOW_EMPTY:${PN}-libgles1-dev = "1" | ||
| 72 | ALLOW_EMPTY:${PN}-libgles2-dev = "1" | ||
| 73 | ALLOW_EMPTY:${PN}-libgles3-dev = "1" | ||
| 74 | RDEPENDS:${PN}-libgles1-dev = "${PN}-libgles-dev" | ||
| 75 | RDEPENDS:${PN}-libgles2-dev = "${PN}-libgles-dev" | ||
| 76 | RDEPENDS:${PN}-libgles3-dev = "${PN}-libgles-dev" | ||
| 77 | |||
| 78 | FILES:${PN}-opencl-icd-dev = " \ | ||
| 79 | ${bindir}/mali_clcc" | ||
| 80 | |||
| 81 | python __anonymous() { | ||
| 82 | |||
| 83 | # Avoid Debian-renaming | ||
| 84 | for p in (("libegl", "libegl1" ), | ||
| 85 | ("libgbm", "libgbm1" ), | ||
| 86 | ("libgles1", "libglesv1-cm1"), | ||
| 87 | ("libgles2", "libglesv2-2" ), | ||
| 88 | ("libgles3", )): | ||
| 89 | fullp = "${PN}-" + p[0] | ||
| 90 | pkgs = "".join(' %s' % i for i in p) | ||
| 91 | d.setVar("DEBIAN_NOAUTONAME:" + fullp, "1") | ||
| 92 | d.appendVar("RREPLACES:" + fullp, pkgs) | ||
| 93 | d.appendVar("RPROVIDES:" + fullp, pkgs) | ||
| 94 | d.appendVar("RCONFLICTS:" + fullp, pkgs) | ||
| 95 | # libmali.so is loaded with dlopen, so an explicit runtime dependency is necessary | ||
| 96 | d.appendVar("RDEPENDS:" + fullp, "${PN}") | ||
| 97 | |||
| 98 | # For -dev, the first element is both the Debian and original name | ||
| 99 | fullp += "-dev" | ||
| 100 | pkgs = p[0] + "-dev" | ||
| 101 | d.setVar("DEBIAN_NOAUTONAME:" + fullp, "1") | ||
| 102 | d.appendVar("RREPLACES:" + fullp, pkgs) | ||
| 103 | d.appendVar("RPROVIDES:" + fullp, pkgs) | ||
| 104 | d.appendVar("RCONFLICTS:" + fullp, pkgs) | ||
| 105 | } | ||
| 106 | |||
| 107 | COMPATIBLE_MACHINE = "(mx95-nxp-bsp)" | ||
diff --git a/recipes-graphics/mali/mali-imx_r50.0.bb b/recipes-graphics/mali/mali-imx_r50.0.bb new file mode 100644 index 000000000..3d30f4685 --- /dev/null +++ b/recipes-graphics/mali/mali-imx_r50.0.bb | |||
| @@ -0,0 +1,25 @@ | |||
| 1 | require mali-imx.inc | ||
| 2 | |||
| 3 | LICENSE = "Proprietary" | ||
| 4 | LIC_FILES_CHKSUM = "file://COPYING;md5=ca53281cc0caa7e320d4945a896fb837" | ||
| 5 | |||
| 6 | SRC_URI = "${FSL_MIRROR}/${BPN}-${PV}-${IMX_SRCREV_ABBREV}.bin;fsl-eula=true" | ||
| 7 | SRC_URI[sha256sum] = "a787a3285c3e288eedacf1a746de2bc9f5fdc15f35cf8b6147deb436183baf6f" | ||
| 8 | IMX_SRCREV_ABBREV = "39604c3" | ||
| 9 | |||
| 10 | S = "${WORKDIR}/${BPN}-${PV}-${IMX_SRCREV_ABBREV}" | ||
| 11 | |||
| 12 | inherit fsl-eula-unpack | ||
| 13 | |||
| 14 | do_install () { | ||
| 15 | install -d ${D} | ||
| 16 | cp -r ${S}/etc ${S}/usr ${D} | ||
| 17 | |||
| 18 | # Move firmware to nonarch_base_libdir | ||
| 19 | if [ "${base_libdir}" != "${nonarch_base_libdir}" ]; then | ||
| 20 | install -d ${D}${nonarch_base_libdir} | ||
| 21 | mv ${D}${base_libdir}/firmware ${D}${nonarch_base_libdir} | ||
| 22 | fi | ||
| 23 | } | ||
| 24 | |||
| 25 | PACKAGE_ARCH = "${MACHINE_SOCARCH}" | ||
