hc
2024-03-26 e0728245c89800c2038c23308f2d88969d5b41c8
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
################################################################################
#
# firmware-imx
#
################################################################################
 
FIRMWARE_IMX_VERSION = 8.12
FIRMWARE_IMX_SITE = $(FREESCALE_IMX_SITE)
FIRMWARE_IMX_SOURCE = firmware-imx-$(FIRMWARE_IMX_VERSION).bin
 
FIRMWARE_IMX_LICENSE = NXP Semiconductor Software License Agreement
FIRMWARE_IMX_LICENSE_FILES = EULA COPYING
FIRMWARE_IMX_REDISTRIBUTE = NO
 
FIRMWARE_IMX_INSTALL_IMAGES = YES
 
define FIRMWARE_IMX_EXTRACT_CMDS
   $(call FREESCALE_IMX_EXTRACT_HELPER,$(FIRMWARE_IMX_DL_DIR)/$(FIRMWARE_IMX_SOURCE))
endef
 
#
# DDR firmware
#
 
define FIRMWARE_IMX_PREPARE_DDR_FW
   $(TARGET_OBJCOPY) -I binary -O binary \
       --pad-to $(BR2_PACKAGE_FIRMWARE_IMX_IMEM_LEN) --gap-fill=0x0 \
       $(FIRMWARE_IMX_DDRFW_DIR)/$(strip $(1)).bin \
       $(FIRMWARE_IMX_DDRFW_DIR)/$(strip $(1))_pad.bin
   $(TARGET_OBJCOPY) -I binary -O binary \
       --pad-to $(BR2_PACKAGE_FIRMWARE_IMX_DMEM_LEN) --gap-fill=0x0 \
       $(FIRMWARE_IMX_DDRFW_DIR)/$(strip $(2)).bin \
       $(FIRMWARE_IMX_DDRFW_DIR)/$(strip $(2))_pad.bin
   cat $(FIRMWARE_IMX_DDRFW_DIR)/$(strip $(1))_pad.bin \
       $(FIRMWARE_IMX_DDRFW_DIR)/$(strip $(2))_pad.bin > \
       $(FIRMWARE_IMX_DDRFW_DIR)/$(strip $(3)).bin
endef
 
ifeq ($(BR2_PACKAGE_FIRMWARE_IMX_LPDDR4),y)
FIRMWARE_IMX_DDRFW_DIR = $(@D)/firmware/ddr/synopsys
 
define FIRMWARE_IMX_INSTALL_IMAGE_DDR_FW
   # Create padded versions of lpddr4_pmu_* and generate lpddr4_pmu_train_fw.bin.
   # lpddr4_pmu_train_fw.bin is needed when generating imx8-boot-sd.bin
   # which is done in post-image script.
   $(call FIRMWARE_IMX_PREPARE_DDR_FW, \
       lpddr4_pmu_train_1d_imem,lpddr4_pmu_train_1d_dmem,lpddr4_pmu_train_1d_fw)
   $(call FIRMWARE_IMX_PREPARE_DDR_FW, \
       lpddr4_pmu_train_2d_imem,lpddr4_pmu_train_2d_dmem,lpddr4_pmu_train_2d_fw)
   cat $(FIRMWARE_IMX_DDRFW_DIR)/lpddr4_pmu_train_1d_fw.bin \
       $(FIRMWARE_IMX_DDRFW_DIR)/lpddr4_pmu_train_2d_fw.bin > \
       $(BINARIES_DIR)/lpddr4_pmu_train_fw.bin
   ln -sf $(BINARIES_DIR)/lpddr4_pmu_train_fw.bin $(BINARIES_DIR)/ddr_fw.bin
 
   # U-Boot supports creation of the combined flash.bin image. To make
   # sure that U-Boot can access all available files copy them to
   # the binary dir.
   cp $(FIRMWARE_IMX_DDRFW_DIR)/lpddr4*.bin $(BINARIES_DIR)/
endef
endif
 
ifeq ($(BR2_PACKAGE_FIRMWARE_IMX_DDR4),y)
FIRMWARE_IMX_DDRFW_DIR = $(@D)/firmware/ddr/synopsys
 
define FIRMWARE_IMX_INSTALL_IMAGE_DDR_FW
   # Create padded versions of ddr4_* and generate ddr4_fw.bin.
   # ddr4_fw.bin is needed when generating imx8-boot-sd.bin
   # which is done in post-image script.
   $(call FIRMWARE_IMX_PREPARE_DDR_FW, \
       ddr4_imem_1d_201810,ddr4_dmem_1d_201810,ddr4_1d_201810_fw)
   $(call FIRMWARE_IMX_PREPARE_DDR_FW, \
       ddr4_imem_2d_201810,ddr4_dmem_2d_201810,ddr4_2d_201810_fw)
   cat $(FIRMWARE_IMX_DDRFW_DIR)/ddr4_1d_201810_fw.bin \
       $(FIRMWARE_IMX_DDRFW_DIR)/ddr4_2d_201810_fw.bin > \
       $(BINARIES_DIR)/ddr4_201810_fw.bin
   ln -sf $(BINARIES_DIR)/ddr4_201810_fw.bin $(BINARIES_DIR)/ddr_fw.bin
 
   # U-Boot supports creation of the combined flash.bin image. To make
   # sure that U-Boot can access all available files copy them to
   # the binary dir.
   cp $(FIRMWARE_IMX_DDRFW_DIR)/ddr4*.bin $(BINARIES_DIR)/
endef
endif
 
#
# HDMI firmware
#
 
ifeq ($(BR2_PACKAGE_FIRMWARE_IMX_NEEDS_HDMI_FW),y)
define FIRMWARE_IMX_INSTALL_IMAGE_HDMI_FW
   cp $(@D)/firmware/hdmi/cadence/signed_hdmi_imx8m.bin \
       $(BINARIES_DIR)/signed_hdmi_imx8m.bin
endef
endif
 
#
# EPDC firmware
#
 
ifeq ($(BR2_PACKAGE_FIRMWARE_IMX_NEEDS_EPDC_FW),y)
define FIRMWARE_IMX_INSTALL_TARGET_EPDC_FW
   mkdir -p $(TARGET_DIR)/lib/firmware/imx
   cp -r $(@D)/firmware/epdc $(TARGET_DIR)/lib/firmware/imx
   mv $(TARGET_DIR)/lib/firmware/imx/epdc/epdc_ED060XH2C1.fw.nonrestricted \
       $(TARGET_DIR)/lib/firmware/imx/epdc/epdc_ED060XH2C1.fw
endef
endif
 
#
# SDMA firmware
#
 
FIRMWARE_IMX_SDMA_FW_NAME = $(call qstrip,$(BR2_PACKAGE_FIRMWARE_IMX_SDMA_FW_NAME))
ifneq ($(FIRMWARE_IMX_SDMA_FW_NAME),)
define FIRMWARE_IMX_INSTALL_TARGET_SDMA_FW
   mkdir -p $(TARGET_DIR)/lib/firmware/imx/sdma
   cp -r $(@D)/firmware/sdma/sdma-$(FIRMWARE_IMX_SDMA_FW_NAME)*.bin \
          $(TARGET_DIR)/lib/firmware/imx/sdma/
endef
endif
 
#
# VPU firmware
#
 
FIRMWARE_IMX_VPU_FW_NAME = $(call qstrip,$(BR2_PACKAGE_FIRMWARE_IMX_VPU_FW_NAME))
ifneq ($(FIRMWARE_IMX_VPU_FW_NAME),)
define FIRMWARE_IMX_INSTALL_TARGET_VPU_FW
   mkdir -p $(TARGET_DIR)/lib/firmware/vpu
   for i in $$(find $(@D)/firmware/vpu/vpu_fw_$(FIRMWARE_IMX_VPU_FW_NAME)*.bin); do \
       cp $$i $(TARGET_DIR)/lib/firmware/vpu/ ; \
       ln -sf vpu/$$(basename $$i) $(TARGET_DIR)/lib/firmware/$$(basename $$i) ; \
   done
endef
endif
 
define FIRMWARE_IMX_INSTALL_IMAGES_CMDS
   $(FIRMWARE_IMX_INSTALL_IMAGE_DDR_FW)
   $(FIRMWARE_IMX_INSTALL_IMAGE_HDMI_FW)
endef
 
define FIRMWARE_IMX_INSTALL_TARGET_CMDS
   $(FIRMWARE_IMX_INSTALL_TARGET_EPDC_FW)
   $(FIRMWARE_IMX_INSTALL_TARGET_SDMA_FW)
   $(FIRMWARE_IMX_INSTALL_TARGET_VPU_FW)
endef
 
$(eval $(generic-package))