blob: 4ab3116ee003153635acaded32f295b599be1567 [file] [log] [blame]
Peng Fan39c5ba22018-11-20 10:19:46 +00001#!/bin/sh
2# SPDX-License-Identifier: GPL-2.0+
3#
4# script to check whether the file exists in imximage.cfg for i.MX8M
5#
6
7file=$1
8
9post_process=$2
10
11blobs=`awk '/^SIGNED_HDMI/ {print $2} /^LOADER/ {print $2} /^SECOND_LOADER/ {print $2} /^DDR_FW/ {print $2}' $file`
12for f in $blobs; do
Baruch Siach10e31942019-01-02 08:58:28 +020013 if [ $f = "spl/u-boot-spl-ddr.bin" ] || [ $f = "u-boot.itb" ]; then
Peng Fan39c5ba22018-11-20 10:19:46 +000014 continue
15 fi
16
Sébastien Szymanski34d92242020-01-21 11:58:42 +010017 if [ ! -f $f ]; then
18 echo "WARNING '$f' not found, resulting binary is not-functional" >&2
Peng Fan39c5ba22018-11-20 10:19:46 +000019 exit 1
20 fi
Peng Fan39c5ba22018-11-20 10:19:46 +000021done
22
Baruch Siach10e31942019-01-02 08:58:28 +020023if [ $post_process = 1 ]; then
Frieder Schrempf5f774dd2019-12-11 10:06:06 +000024 if [ -f lpddr4_pmu_train_1d_imem.bin ]; then
25 objcopy -I binary -O binary --pad-to 0x8000 --gap-fill=0x0 lpddr4_pmu_train_1d_imem.bin lpddr4_pmu_train_1d_imem_pad.bin
26 objcopy -I binary -O binary --pad-to 0x4000 --gap-fill=0x0 lpddr4_pmu_train_1d_dmem.bin lpddr4_pmu_train_1d_dmem_pad.bin
27 objcopy -I binary -O binary --pad-to 0x8000 --gap-fill=0x0 lpddr4_pmu_train_2d_imem.bin lpddr4_pmu_train_2d_imem_pad.bin
Peng Fan39c5ba22018-11-20 10:19:46 +000028 cat lpddr4_pmu_train_1d_imem_pad.bin lpddr4_pmu_train_1d_dmem_pad.bin > lpddr4_pmu_train_1d_fw.bin
Frieder Schrempf5f774dd2019-12-11 10:06:06 +000029 cat lpddr4_pmu_train_2d_imem_pad.bin lpddr4_pmu_train_2d_dmem.bin > lpddr4_pmu_train_2d_fw.bin
Peng Fanab9bc382019-08-27 06:24:43 +000030 dd if=spl/u-boot-spl.bin of=spl/u-boot-spl-pad.bin bs=4 conv=sync
31 cat spl/u-boot-spl-pad.bin lpddr4_pmu_train_1d_fw.bin lpddr4_pmu_train_2d_fw.bin > spl/u-boot-spl-ddr.bin
32 rm -f lpddr4_pmu_train_1d_fw.bin lpddr4_pmu_train_2d_fw.bin lpddr4_pmu_train_1d_imem_pad.bin lpddr4_pmu_train_1d_dmem_pad.bin lpddr4_pmu_train_2d_imem_pad.bin spl/u-boot-spl-pad.bin
Peng Fan39c5ba22018-11-20 10:19:46 +000033 fi
Frieder Schrempf5f774dd2019-12-11 10:06:06 +000034 if [ -f ddr4_imem_1d.bin ]; then
35 objcopy -I binary -O binary --pad-to 0x8000 --gap-fill=0x0 ddr4_imem_1d.bin ddr4_imem_1d_pad.bin
36 objcopy -I binary -O binary --pad-to 0x4000 --gap-fill=0x0 ddr4_dmem_1d.bin ddr4_dmem_1d_pad.bin
37 objcopy -I binary -O binary --pad-to 0x8000 --gap-fill=0x0 ddr4_imem_2d.bin ddr4_imem_2d_pad.bin
Peng Fan1333fc02019-09-16 03:09:44 +000038 cat ddr4_imem_1d_pad.bin ddr4_dmem_1d_pad.bin > ddr4_1d_fw.bin
Frieder Schrempf5f774dd2019-12-11 10:06:06 +000039 cat ddr4_imem_2d_pad.bin ddr4_dmem_2d.bin > ddr4_2d_fw.bin
Peng Fan1333fc02019-09-16 03:09:44 +000040 dd if=spl/u-boot-spl.bin of=spl/u-boot-spl-pad.bin bs=4 conv=sync
41 cat spl/u-boot-spl-pad.bin ddr4_1d_fw.bin ddr4_2d_fw.bin > spl/u-boot-spl-ddr.bin
42 rm -f ddr4_1d_fw.bin ddr4_2d_fw.bin ddr4_imem_1d_pad.bin ddr4_dmem_1d_pad.bin ddr4_imem_2d_pad.bin spl/u-boot-spl-pad.bin
43 fi
Ariel D'Alessandroef6d59e2021-09-30 10:31:17 -030044 if [ -f ddr3_imem_1d.bin ]; then
45 objcopy -I binary -O binary --pad-to 0x8000 --gap-fill=0x0 ddr3_imem_1d.bin ddr3_imem_1d_pad.bin
46 cat ddr3_imem_1d_pad.bin ddr3_dmem_1d.bin > ddr3_1d_fw.bin
47 dd if=spl/u-boot-spl.bin of=spl/u-boot-spl-pad.bin bs=4 conv=sync
48 cat spl/u-boot-spl-pad.bin ddr3_1d_fw.bin > spl/u-boot-spl-ddr.bin
49 rm -f ddr3_1d_fw.bin ddr3_imem_1d_pad.bin spl/u-boot-spl-pad.bin
50 fi
Peng Fan39c5ba22018-11-20 10:19:46 +000051fi
52
53exit 0