diff options
Diffstat (limited to 'recipes-bsp/firmware/firmware-qcom-rb5_1.0.bb')
-rw-r--r-- | recipes-bsp/firmware/firmware-qcom-rb5_1.0.bb | 46 |
1 files changed, 44 insertions, 2 deletions
diff --git a/recipes-bsp/firmware/firmware-qcom-rb5_1.0.bb b/recipes-bsp/firmware/firmware-qcom-rb5_1.0.bb index b9f43cf..a84c453 100644 --- a/recipes-bsp/firmware/firmware-qcom-rb5_1.0.bb +++ b/recipes-bsp/firmware/firmware-qcom-rb5_1.0.bb @@ -31,6 +31,18 @@ do_install() { if [ -n "${ADRENO_URI}" ] ; then install -d ${D}${nonarch_base_libdir}/firmware/qcom install -m 0444 ./lib/firmware/a650_*.* ${D}${nonarch_base_libdir}/firmware/qcom + else + install -d ${D}${nonarch_base_libdir}/firmware/qcom + install -d ${D}${nonarch_base_libdir}/firmware/system + + install -d ${D}${systemd_system_unitdir} + install -m 0644 ${WORKDIR}/lib-firmware-system.service ${D}${systemd_system_unitdir} + + # Symlink firmware to proper paths. + for img in a650_gmu.bin a650_sqe.fw a650_zap.mdt a650_zap.elf a650_zap.b00 a650_zap.b01 a650_zap.b02 + do + ln -s ../system/lib/firmware/${img} ${D}${nonarch_base_libdir}/firmware/qcom + done fi if [ -n "${NHLOS_URI}" ] ; then @@ -38,14 +50,38 @@ do_install() { install -d ${D}${nonarch_base_libdir}/firmware/qcom/sm8250 install -m 0444 adsp.b* adsp.mdt adspr.jsn adspua.jsn ${D}${nonarch_base_libdir}/firmware/qcom/sm8250 install -m 0444 cdsp.b* cdsp.mdt cdspr.jsn ${D}${nonarch_base_libdir}/firmware/qcom/sm8250 - install -m 0444 slpi.b* slpi.mdt ${D}${nonarch_base_libdir}/firmware/qcom/sm8250 + install -m 0444 slpi.b* slpi.mdt slpir.jsn slpius.jsn ${D}${nonarch_base_libdir}/firmware/qcom/sm8250 install -m 0444 venus.b* venus.mdt ${D}${nonarch_base_libdir}/firmware/qcom/sm8250 install -m 0444 verinfo/Ver_Info.txt ${D}${nonarch_base_libdir}/firmware/qcom/sm8250 + cd .. + else + install -d ${D}${nonarch_base_libdir}/firmware/qcom/sm8250 + install -d ${D}${nonarch_base_libdir}/firmware/modem + + install -d ${D}${systemd_system_unitdir} + install -m 0644 ${WORKDIR}/lib-firmware-modem.service ${D}${systemd_system_unitdir} + + # Unfortunately Qualcomm firmware partition uses different layout there, so we have to symlink firmware to proper paths. + # Bettere be safe than sorry. Install more links that are actually present there in case firmware is changed. + for base in adsp cdsp slpi venus + do + for idx in $(seq 0 20) + do + ln -s ../../modem/image/$base.b`printf %02d $idx` ${D}${nonarch_base_libdir}/firmware/qcom/sm8250 + done + ln -s ../../modem/image/${base}.mdt ${D}${nonarch_base_libdir}/firmware/qcom/sm8250 + done + for img in adspr adspua cdspr slpir slpius + do + ln -s ../../modem/image/${img}.jsn ${D}${nonarch_base_libdir}/firmware/qcom/sm8250 + done fi } -FILES_${PN} += "${nonarch_base_libdir}/firmware/*" +inherit systemd + +FILES_${PN} += "${nonarch_base_libdir}/firmware/" INSANE_SKIP_${PN} += "arch" INHIBIT_PACKAGE_DEBUG_SPLIT = "1" INHIBIT_PACKAGE_STRIP = "1" @@ -61,8 +97,14 @@ python () { if uri != None and uri != "": d.appendVar("SRC_URI", " ${SRC_URI_NHLOS}") d.appendVarFlag('do_unpack', 'depends', ' unzip-native:do_populate_sysroot') + else: + d.appendVar("SRC_URI", " file://lib-firmware-modem.service") + d.appendVar("SYSTEMD_SERVICE_" + d.getVar("PN"), " lib-firmware-modem.service") uri = d.getVar("ADRENO_URI") if uri != None and uri != "": d.appendVar("SRC_URI", " ${SRC_URI_ADRENO}") + else: + d.appendVar("SRC_URI", " file://lib-firmware-system.service") + d.appendVar("SYSTEMD_SERVICE_" + d.getVar("PN"), " lib-firmware-system.service") } |