Complete Yocto mirror with license table for TQMa6UL (2038-compliance)
- 264 license table entries with exact download URLs (224/264 resolved) - Complete sources/ directory with all BitBake recipes - Build configuration: tqma6ul-multi-mba6ulx, spaetzle (musl) - Full traceability for Softwarefreigabeantrag - GCC 13.4.0, Linux 6.6.102, U-Boot 2023.04, musl 1.2.4 - License distribution: GPL-2.0 (24), MIT (23), GPL-2.0+ (18), BSD-3 (16)
This commit is contained in:
89
sources/poky/meta/recipes-devtools/gcc/libgfortran.inc
Normal file
89
sources/poky/meta/recipes-devtools/gcc/libgfortran.inc
Normal file
@@ -0,0 +1,89 @@
|
||||
require gcc-configure-common.inc
|
||||
|
||||
EXTRA_OECONF_PATHS = "\
|
||||
--with-sysroot=/not/exist \
|
||||
--with-build-sysroot=${STAGING_DIR_TARGET} \
|
||||
"
|
||||
|
||||
# An arm hard float target like raspberrypi4 won't build
|
||||
# as CFLAGS don't make it to the fortran compiler otherwise
|
||||
# (the configure script sets FC to $GFORTRAN unconditionally)
|
||||
export GFORTRAN = "${FC} -fcanon-prefix-map -fdebug-prefix-map=${S}=${TARGET_DBGSRC_DIR} -fdebug-prefix-map=${B}=${TARGET_DBGSRC_DIR} -gno-record-gcc-switches"
|
||||
|
||||
do_configure () {
|
||||
for target in libbacktrace libgfortran
|
||||
do
|
||||
rm -rf ${B}/${TARGET_SYS}/$target/
|
||||
mkdir -p ${B}/${TARGET_SYS}/$target/
|
||||
cd ${B}/${TARGET_SYS}/$target/
|
||||
chmod a+x ${S}/$target/configure
|
||||
relpath=${@os.path.relpath("${S}", "${B}/${TARGET_SYS}")}
|
||||
../$relpath/$target/configure ${CONFIGUREOPTS} ${EXTRA_OECONF}
|
||||
# Easiest way to stop bad RPATHs getting into the library since we have a
|
||||
# broken libtool here
|
||||
sed -i -e 's/hardcode_into_libs=yes/hardcode_into_libs=no/' ${B}/${TARGET_SYS}/$target/libtool
|
||||
done
|
||||
}
|
||||
EXTRACONFFUNCS += "extract_stashed_builddir"
|
||||
do_configure[depends] += "${COMPILERDEP}"
|
||||
|
||||
do_compile () {
|
||||
for target in libbacktrace libgfortran
|
||||
do
|
||||
cd ${B}/${TARGET_SYS}/$target/
|
||||
oe_runmake MULTIBUILDTOP=${B}/${TARGET_SYS}/$target/
|
||||
done
|
||||
}
|
||||
|
||||
do_install () {
|
||||
cd ${B}/${TARGET_SYS}/libgfortran/
|
||||
oe_runmake 'DESTDIR=${D}' MULTIBUILDTOP=${B}/${TARGET_SYS}/libgfortran/ install
|
||||
if [ -d ${D}${libdir}/gcc/${TARGET_SYS}/${BINV}/finclude ]; then
|
||||
rmdir --ignore-fail-on-non-empty -p ${D}${libdir}/gcc/${TARGET_SYS}/${BINV}/finclude
|
||||
fi
|
||||
if [ -d ${D}${infodir} ]; then
|
||||
rmdir --ignore-fail-on-non-empty -p ${D}${infodir}
|
||||
fi
|
||||
chown -R root:root ${D}
|
||||
}
|
||||
|
||||
# avoid virtual/libc
|
||||
INHIBIT_DEFAULT_DEPS = "1"
|
||||
DEPENDS = "virtual/${HOST_PREFIX}gcc virtual/${HOST_PREFIX}compilerlibs"
|
||||
|
||||
BBCLASSEXTEND = "nativesdk"
|
||||
|
||||
PACKAGES = "\
|
||||
${PN}-dbg \
|
||||
libgfortran \
|
||||
libgfortran-dev \
|
||||
libgfortran-staticdev \
|
||||
"
|
||||
|
||||
LICENSE:${PN} = "GPL-3.0-with-GCC-exception"
|
||||
LICENSE:${PN}-dev = "GPL-3.0-with-GCC-exception"
|
||||
LICENSE:${PN}-dbg = "GPL-3.0-with-GCC-exception"
|
||||
|
||||
FILES:${PN} = "${libdir}/libgfortran.so.*"
|
||||
FILES:${PN}-dev = "\
|
||||
${libdir}/libgfortran*.so \
|
||||
${libdir}/libgfortran.spec \
|
||||
${libdir}/libgfortran.la \
|
||||
${libdir}/gcc/${TARGET_SYS}/${BINV}/libgfortranbegin.* \
|
||||
${libdir}/gcc/${TARGET_SYS}/${BINV}/libcaf_single* \
|
||||
${libdir}/gcc/${TARGET_SYS}/${BINV}/finclude/ \
|
||||
${libdir}/gcc/${TARGET_SYS}/${BINV}/include/ \
|
||||
"
|
||||
FILES:${PN}-staticdev = "${libdir}/libgfortran.a"
|
||||
|
||||
INSANE_SKIP:${MLPREFIX}libgfortran-dev = "staticdev"
|
||||
|
||||
do_package_write_ipk[depends] += "virtual/${MLPREFIX}libc:do_packagedata"
|
||||
do_package_write_deb[depends] += "virtual/${MLPREFIX}libc:do_packagedata"
|
||||
do_package_write_rpm[depends] += "virtual/${MLPREFIX}libc:do_packagedata"
|
||||
|
||||
python __anonymous () {
|
||||
f = d.getVar("FORTRAN")
|
||||
if "fortran" not in f:
|
||||
raise bb.parse.SkipRecipe("libgfortran needs fortran support to be enabled in the compiler")
|
||||
}
|
||||
Reference in New Issue
Block a user