blob: 0c4e07819abfc68aef09da96e9f2fbac93b7601e [file] [log] [blame]
yu.dongc33b3072024-08-21 23:14:49 -07001#!/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#* TCMmargin.pl
40#*
41#* Project:
42#* --------
43#*
44#*
45#* Description:
46#* ------------
47#* This perl is used to get TCM margin
48#*
49#*
50#* Author:
51#* -------
52#* Carl Kao (mtk08237)
53#*
54#****************************************************************************/
55
56BEGIN { push @INC, "./" , '../', './tools/', './tools/MemoryUtility/' } # add additional library path
57use systemInfo;
58use LinkerOutputParser;
59use CommonUtility;
60use FileInfoParser;
61use strict;
62
63#****************************************************************************
64# Constants
65#****************************************************************************
66my $TCMMARGIN_VERNO = " LR12_v0.01";
67 # LR12_v0.01 , 2016/01/25, Memory Utility Refinement for LR12
68 # u0.01 , 2015/01/19, Memory Utility Refinement for LR11
69 # m0.03 , 2012/08/03, Shows more TCM information(Physical size)
70 # m0.02 , 2012/08/03, Push additional library path
71 # m0.01 , 2012/07/21, Initial revision
72
73#****************************************************************************
74# Global variable
75#****************************************************************************
76my $DebugPrint = 0;
77
78#****************************************************************************
79# Subroutine: TCMmargin_verno - to query this package's version number
80# Parameters: x
81# Returns: version number string
82#****************************************************************************
83sub TCMmargin_verno
84{
85 return $TCMMARGIN_VERNO;
86}
87
88#****************************************************************************
89# 1 >>> Get in put parameters
90#****************************************************************************
91&Usage() if($#ARGV != 2);
92my ($makeFile, $memorymapfile, $linkeroutputfile) = @ARGV;
93
94#****************************************************************************
95# 2 >>> Parse make file
96#****************************************************************************
97my %MAKEFILE_OPTIONS;
98&FileInfo::Parse_MAKEFILE($makeFile, \%MAKEFILE_OPTIONS);
99
100#****************************************************************************
101# 3 >>> Calculate TCM margin
102#****************************************************************************
103&CalcTCMmargin();
104
105#****************************************************************************
106# oo >>> Finished
107#****************************************************************************
108exit 0;
109
110#****************************************************************************
111# subroutine: CalcTCMmargin - calculate TCM margin
112# Input: x
113# Output: x
114#****************************************************************************
115sub CalcTCMmargin
116{
117 my %ChipInsideRam_region;
118 my $nChipInsideRAMnum = 0;
119 my %ChipInsideRAMinfo;
120 my $TCMmargin_href;
121
122 # Get all chipInsideRAM regions
123 $nChipInsideRAMnum = &sysInfo::GetChipInsideRAMregion($memorymapfile, \%ChipInsideRam_region, \%MAKEFILE_OPTIONS);
124
125 # Parse link output file
126 &LinkerOutputParser::FileParse($linkeroutputfile);
127
128 # Get the size of all chipInsideRAM regions and store to a Hash
129 foreach my $strRegionName (keys %ChipInsideRam_region)
130 {
131 $ChipInsideRAMinfo{$strRegionName}[0] = # 0: size
132 &LinkerOutputParser::GetTotalSizeByExeRegion($strRegionName);
133 $ChipInsideRAMinfo{$strRegionName}[1] = # 1: VMA
134 &LinkerOutputParser::GetVMAByExeRegion($strRegionName);
135 }
136
137 # Get TCM margin via the Hash content TCM size info
138 $TCMmargin_href = &sysInfo::GetTCMmargin($memorymapfile, \%ChipInsideRAMinfo, \%MAKEFILE_OPTIONS);
139
140 # Print TCM margin
141 print ("-------------------------------------------------------------------\n");
142
143 my @sorted_keys = sort {
144 my @aa = $a =~ /^([A-Za-z]+)(\d*)$/;
145 my @bb = $b =~ /^([A-Za-z]+)(\d*)$/;
146 $aa[1] <=> $bb[1] or lc $aa[0] cmp lc $bb[0];
147 } keys %$TCMmargin_href;
148
149 # foreach my $strRegionname (sort keys %$TCMmargin_href) # old way, no sort
150 for (my $i=0; $i<2; ++$i)
151 {
152 foreach (@sorted_keys)
153 {
154 my $strRegionname = $_;
155
156 next if ( $i == 0 && $strRegionname !~ /\d$/ ); # show per-core part in first round
157 next if ( $i == 1 && $strRegionname =~ /\d$/ ); # show common part in first round
158
159 printf("%10s %20s 0x%08x = %8d bytes = %5d KB\n", $strRegionname, "physical size = ",
160 $TCMmargin_href->{$strRegionname}->[0],
161 $TCMmargin_href->{$strRegionname}->[0],
162 $TCMmargin_href->{$strRegionname}->[0]/1024);
163 printf("%10s %20s 0x%08x = %8d bytes = %5d KB \n", $strRegionname, "margin = ",
164 $TCMmargin_href->{$strRegionname}->[1],
165 $TCMmargin_href->{$strRegionname}->[1],
166 $TCMmargin_href->{$strRegionname}->[1]/1024);
167 #reserve for debugging
168 #printf("%10s %20s 0x%08x KB \n", $strRegionname, "end addr = ", ($TCMmargin_href->{$strRegionname}->[0]-$TCMmargin_href->{$strRegionname}->[1]));
169 print ("-------------------------------------------------------------------\n");
170 }
171 }
172}
173
174#****************************************************************************
175# subroutine: Usage - usage template
176# Input: x
177# Output: x
178#****************************************************************************
179sub Usage
180{
181 print <<"__EOFUSAGE";
182
183usage: perl TCMMargin.pl makefile_path scatter_file_path/lds_file_path lis_file_path/sym_file_path
184
185NOTE: scatter file should input with lis file
186 lds file should input with sym file
187
188e.g.
189perl TCMMargin.pl "/[path]/MT6280_R7R8_HSPA(FULL_VERSION_RVCT).mak" "/[path]/scatMT6280_R7R8.txt" "/[path]/MT6280_EVB_R7R8_PCB01_hspa_MT6280_S00.lis"
190
191__EOFUSAGE
192
193 exit 1;
194}
195