blob: 2427afee3a52f6337d7c062b9c58019f1e26a493 [file] [log] [blame]
rjw6c1fd8f2022-11-30 14:33:01 +08001#!/usr/bin/perl
2#
3# Copyright Statement:
4# --------------------
5# This software is protected by Copyright and the information contained
6# herein is confidential. The software may not be copied and the information
7# contained herein may not be used or disclosed except with the written
8# permission of MediaTek Inc. (C) 2006
9#
10# BY OPENING THIS FILE, BUYER HEREBY UNEQUIVOCALLY ACKNOWLEDGES AND AGREES
11# THAT THE SOFTWARE/FIRMWARE AND ITS DOCUMENTATIONS ("MEDIATEK SOFTWARE")
12# RECEIVED FROM MEDIATEK AND/OR ITS REPRESENTATIVES ARE PROVIDED TO BUYER ON
13# AN "AS-IS" BASIS ONLY. MEDIATEK EXPRESSLY DISCLAIMS ANY AND ALL WARRANTIES,
14# EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES OF
15# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NONINFRINGEMENT.
16# NEITHER DOES MEDIATEK PROVIDE ANY WARRANTY WHATSOEVER WITH RESPECT TO THE
17# SOFTWARE OF ANY THIRD PARTY WHICH MAY BE USED BY, INCORPORATED IN, OR
18# SUPPLIED WITH THE MEDIATEK SOFTWARE, AND BUYER AGREES TO LOOK ONLY TO SUCH
19# THIRD PARTY FOR ANY WARRANTY CLAIM RELATING THERETO. MEDIATEK SHALL ALSO
20# NOT BE RESPONSIBLE FOR ANY MEDIATEK SOFTWARE RELEASES MADE TO BUYER'S
21# SPECIFICATION OR TO CONFORM TO A PARTICULAR STANDARD OR OPEN FORUM.
22#
23# BUYER'S SOLE AND EXCLUSIVE REMEDY AND MEDIATEK'S ENTIRE AND CUMULATIVE
24# LIABILITY WITH RESPECT TO THE MEDIATEK SOFTWARE RELEASED HEREUNDER WILL BE,
25# AT MEDIATEK'S OPTION, TO REVISE OR REPLACE THE MEDIATEK SOFTWARE AT ISSUE,
26# OR REFUND ANY SOFTWARE LICENSE FEES OR SERVICE CHARGE PAID BY BUYER TO
27# MEDIATEK FOR SUCH MEDIATEK SOFTWARE AT ISSUE.
28#
29# THE TRANSACTION CONTEMPLATED HEREUNDER SHALL BE CONSTRUED IN ACCORDANCE
30# WITH THE LAWS OF THE STATE OF CALIFORNIA, USA, EXCLUDING ITS CONFLICT OF
31# LAWS PRINCIPLES. ANY DISPUTES, CONTROVERSIES OR CLAIMS ARISING THEREOF AND
32# RELATED THERETO SHALL BE SETTLED BY ARBITRATION IN SAN FRANCISCO, CA, UNDER
33# THE RULES OF THE INTERNATIONAL CHAMBER OF COMMERCE (ICC).
34#
35#*****************************************************************************
36#*
37#* Filename:
38#* ---------
39#* copro_injection.pl
40#*
41#* Project:
42#* --------
43#*
44#*
45#* Description:
46#* ------------
47#* This script is used to parse copro information
48#*
49#*
50#* Author:
51#* -------
52#* Carl Kao (mtk08237)
53#*
54#*------------------------------------------------------------------------------
55#* Upper this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
56#*============================================================================
57#****************************************************************************/
58#****************************************************************************
59# Included Modules
60#****************************************************************************
61use strict;
62BEGIN { push @INC, './pcore/tools/', './common/tools/MemoryUtility/' } # add additional library path
63use CommonUtility;
64use SymFileParser;
65use FileInfoParser;
66use File::Copy;
67use File::Basename;
68
69#****************************************************************************
70# Constants
71#****************************************************************************
72my $VERNO = " u0.05";
73 # u0.05, 2015/06/25, Carl, Refine error message for avoid false alarm in EWS build
74 # u0.04 , 2015/01/19, Carl, Memory Utility Refinement
75 # u0.03 , 2014/05/07, Carl, 2-phase linking
76 # u0.02 , 2014/03/03, BM, Change include path
77 # u0.01 , 2014/02/20, Carl, Initial revision
78
79#****************************************************************************
80# Input
81#****************************************************************************
82
83my $themf = $ARGV[0];
84my $INFOMAKELOG = $ARGV[1];
85my $COPRO_INJECTION_TEMP = $ARGV[2];
86my $BM_NEW = $ARGV[3];
87
88print "copro_injection input:\n";
89print map{ "\t".$_."\n" } @ARGV ;
90
91#****************************************************************************
92# Global Variables
93#****************************************************************************
94my %g_MKFILE;
95my %g_CmplOpt;
96my %g_RelInfo;
97my %g_PathInfo;
98
99
100exit 0;
101#****************************************************************************
102# >>> Main Flow
103#****************************************************************************
104FileInfo::PreProcess($themf, \%g_MKFILE, $INFOMAKELOG, \%g_CmplOpt, \%g_RelInfo, 1);
105SetPathInfo($COPRO_INJECTION_TEMP, \%g_PathInfo);
106
107#****************************************************************************
108# >>> Avoid flase alarm in bm_new
109#****************************************************************************
110{
111 if($BM_NEW eq "bm_new")
112 {
113 my $file_not_found = 0;
114
115 print("[Parameter 1] pcore sym file doesn't exist. \"Please fix pcore build fail (check log message in log folder) to avoid this build check!\"",
116 __FILE__, " ", __LINE__, "\n") if( !-e GetPath("MAIN_SYM") );
117 print("[Parameter 2] l1core bin file doesn't exist. \"Please fix l1core build fail (check log message in log folder) to avoid this build check!\"",
118 __FILE__, " ", __LINE__, "\n") if( !-e GetPath("L1CORE_BIN") );
119
120 exit 0 if( !-e GetPath("MAIN_SYM") or !-e GetPath("L1CORE_BIN") );
121 }
122}
123
124#######################
125# FIX_ME what is th condition?
126#######################
127#if(FileInfo::is_BuiltWithCopro())
128{
129 SymFileParser::ParseSYM(GetPath("MAIN_SYM"));
130
131 my $CoproInfo_href = GetL1coreInfo(GetPath("MAIN_SYM"), "L1CORE");
132
133# my ($nReservedCoproSize, $nCoproOffset) = ($CoproInfo_href->{COPRO}[0], $CoproInfo_href->{COPRO}[1]);
134# print "ReservedCoproSize= $nReservedCoproSize(".CommonUtil::Dec2Hex($nReservedCoproSize).
135# "), ElfOffset= $nCoproOffset(".CommonUtil::Dec2Hex($nCoproOffset).")\n";
136
137 my ($nReservedL1CORESize, $nL1COREOffset) = ($CoproInfo_href->{L1CORE_LV}[0], $CoproInfo_href->{L1CORE_LV}[1]);
138 print "nReservedL1CORESize= $nReservedL1CORESize(".CommonUtil::Dec2Hex($nReservedL1CORESize).
139 "), ElfOffset= $nL1COREOffset(".CommonUtil::Dec2Hex($nL1COREOffset).")\n";
140
141# CheckCopyBytes(GetPath("COPRO_BIN"), $nReservedCoproSize) if(FileInfo::is_Copro());
142
143 CheckCopyBytes(GetPath("L1CORE_BIN"), $nReservedL1CORESize);# if(FileInfo::is("MD_OFFLOAD_COPRO", "MP300"));
144 copy(GetPath("MAIN_ELF"), GetPath("BACKUP_ELF")); #Backup
145
146# Inject(GetPath("MAIN_ELF"), GetPath("COPRO_BIN"), $nCoproOffset) if(FileInfo::is_Copro());
147
148 Inject(GetPath("MAIN_ELF"), GetPath("L1CORE_BIN"), $nL1COREOffset)# if(FileInfo::is("MD_OFFLOAD_COPRO", "MP300"));
149}
150
151exit 0;
152#****************************************************************************
153# Subroutines
154#****************************************************************************
155sub CheckCopyBytes
156{
157 my ($strInputFilePath, $nL1CORESize) = @_;
158 my $nBinSize = -s $strInputFilePath;
159 print "BinSize=$nBinSize(".CommonUtil::Dec2Hex($nBinSize).")\n";
160 if($nL1CORESize < $nBinSize)
161 {
162 copro_inject_die("ReservedCoproSize($nL1CORESize) is smaller than CoproBinarySize($nBinSize)\n");
163 }
164}
165
166sub GetPath
167{
168 my ($strKeyword) = @_; #keyword is defined in build.mak's copro_injection
169 return $g_PathInfo{$strKeyword};
170}
171
172sub SetPathInfo
173{
174 my ($strInfoPath, $PathInfo_href) = @_;
175 my $strContent = CommonUtil::GetFileContent($strInfoPath);
176 CommonUtil::HashStringParser($strContent, $PathInfo_href);
177}
178
179
180sub GetL1coreInfo
181{
182 my ($strSYM_FILE, $strRegionKeyWord) = @_;
183 my ($nReservedCoproSize, $nOffset) = (0,0);
184 my %L1coreInfo; # ERName=> [$nReservedCoproSize, $nOffset]
185 my $AllERs_aref = SymFileParser::ListAllExeRegion(1);
186 foreach my $ER (@$AllERs_aref)
187 {
188 if($ER =~ /$strRegionKeyWord/i)
189 {
190 my $strReservedL1coreSize = SymFileParser::GetExeRegionInfo($ER, Region::Size);
191 my $strOffset = SymFileParser::GetExeRegionInfo($ER, Region::Offsets);
192 $L1coreInfo{$ER} = [hex($strReservedL1coreSize), hex($strOffset)];
193 }
194 }
195 return \%L1coreInfo;
196}
197
198sub Inject
199{
200 my ($strTargetFilePath, $strInputFilePath, $nOffsetStart) = @_;
201 my $CoproBin = GetL1coreBinContent($strInputFilePath);
202 my $nBinSize = -s $strInputFilePath;
203 my $nElfSize = -s $strTargetFilePath;
204 my $TopElf = GetElfContent($strTargetFilePath, 0, $nOffsetStart );
205 my $BottomElf = GetElfContent($strTargetFilePath, $nOffsetStart+$nBinSize, $nElfSize-($nOffsetStart+$nBinSize) );
206 open OUTFILE, "+>$strTargetFilePath" or copro_inject_die("$strTargetFilePath: open file error!");
207 binmode OUTFILE;
208 print OUTFILE $TopElf;
209 print OUTFILE $CoproBin;
210 print OUTFILE $BottomElf;
211 close OUTFILE;
212
213 print "--------------------------------------------------------------\n";
214 print "Inject successfully!\n";
215 print "Output File: $strTargetFilePath\n";
216}
217sub GetElfContent
218{
219 my ($strTargetFilePath, $nOffsetStart, $nLength) = @_;
220 print "[GetElf]OffsetBase=$nOffsetStart(".CommonUtil::Dec2Hex($nOffsetStart)."), Length=$nLength(".CommonUtil::Dec2Hex($nLength).")\n";
221 my $LeftELF;
222 open FILE, "+<$strTargetFilePath" or copro_inject_die("$strTargetFilePath: open file error!");
223 binmode FILE;
224 seek FILE, $nOffsetStart, 0 or copro_inject_die("can't reach $nOffsetStart in $strTargetFilePath!");
225 read(FILE, $LeftELF, $nLength);
226 close FILE;
227 return $LeftELF;
228}
229
230sub GetL1coreBinContent
231{
232 my ($strInputFilePath) = @_;
233 my $CoproBin;
234 open FILE, "<$strInputFilePath" or copro_inject_die("$strInputFilePath: open file error!");
235 {
236 binmode FILE;
237 local $/;
238 $CoproBin = <FILE>;
239 }
240 close FILE;
241 return $CoproBin;
242}
243
244sub copro_inject_die
245{
246 my ($error_msg, $file, $line_no) = @_;
247 my $pack_name = undef;
248 if(!defined $file or !defined $line_no)
249 {
250 ($pack_name, $file, $line_no) = caller;
251 }
252 &CommonUtil::error_handler($error_msg, $file, $line_no, 'COPRO_INJECTION');
253}