[Feature]Upload Modem source code

Change-Id: Id4294f30faced84d3e6fd6d5e61e1111bf287a37
diff --git a/mcu/tools/AutoGen/postBuild/ckRegion.pl b/mcu/tools/AutoGen/postBuild/ckRegion.pl
new file mode 100644
index 0000000..35b970d
--- /dev/null
+++ b/mcu/tools/AutoGen/postBuild/ckRegion.pl
@@ -0,0 +1,148 @@
+#!/usr/bin/perl
+#
+#  Copyright Statement:
+#  --------------------
+#  This software is protected by Copyright and the information contained
+#  herein is confidential. The software may not be copied and the information
+#  contained herein may not be used or disclosed except with the written
+#  permission of MediaTek Inc. (C) 2006
+#
+#  BY OPENING THIS FILE, BUYER HEREBY UNEQUIVOCALLY ACKNOWLEDGES AND AGREES
+#  THAT THE SOFTWARE/FIRMWARE AND ITS DOCUMENTATIONS ("MEDIATEK SOFTWARE")
+#  RECEIVED FROM MEDIATEK AND/OR ITS REPRESENTATIVES ARE PROVIDED TO BUYER ON
+#  AN "AS-IS" BASIS ONLY. MEDIATEK EXPRESSLY DISCLAIMS ANY AND ALL WARRANTIES,
+#  EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED WARRANTIES OF
+#  MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NONINFRINGEMENT.
+#  NEITHER DOES MEDIATEK PROVIDE ANY WARRANTY WHATSOEVER WITH RESPECT TO THE
+#  SOFTWARE OF ANY THIRD PARTY WHICH MAY BE USED BY, INCORPORATED IN, OR
+#  SUPPLIED WITH THE MEDIATEK SOFTWARE, AND BUYER AGREES TO LOOK ONLY TO SUCH
+#  THIRD PARTY FOR ANY WARRANTY CLAIM RELATING THERETO. MEDIATEK SHALL ALSO
+#  NOT BE RESPONSIBLE FOR ANY MEDIATEK SOFTWARE RELEASES MADE TO BUYER'S
+#  SPECIFICATION OR TO CONFORM TO A PARTICULAR STANDARD OR OPEN FORUM.
+#
+#  BUYER'S SOLE AND EXCLUSIVE REMEDY AND MEDIATEK'S ENTIRE AND CUMULATIVE
+#  LIABILITY WITH RESPECT TO THE MEDIATEK SOFTWARE RELEASED HEREUNDER WILL BE,
+#  AT MEDIATEK'S OPTION, TO REVISE OR REPLACE THE MEDIATEK SOFTWARE AT ISSUE,
+#  OR REFUND ANY SOFTWARE LICENSE FEES OR SERVICE CHARGE PAID BY BUYER TO
+#  MEDIATEK FOR SUCH MEDIATEK SOFTWARE AT ISSUE.
+#
+#  THE TRANSACTION CONTEMPLATED HEREUNDER SHALL BE CONSTRUED IN ACCORDANCE
+#  WITH THE LAWS OF THE STATE OF CALIFORNIA, USA, EXCLUDING ITS CONFLICT OF
+#  LAWS PRINCIPLES.  ANY DISPUTES, CONTROVERSIES OR CLAIMS ARISING THEREOF AND
+#  RELATED THERETO SHALL BE SETTLED BY ARBITRATION IN SAN FRANCISCO, CA, UNDER
+#  THE RULES OF THE INTERNATIONAL CHAMBER OF COMMERCE (ICC).
+#
+#*****************************************************************************
+#*
+#* Filename:
+#* ---------
+#*   ckRegion.pl
+#*
+#* Project:
+#* --------
+#*
+#*
+#* Description:
+#* ------------
+#*   This scripts parses symbolfile and checks does it have any overlapping
+#*   regions in physical SRAM
+#*       
+#*
+#* Author:
+#* -------
+#*   Tero Jarkko (mtk09602)
+#*
+#****************************************************************************/
+
+#****************************************************************************
+# Verno
+#****************************************************************************
+my $version = "Gen93_v0.02";
+             # Gen93_v0.02, 2017/09/01,  Carl, support overlapped drdi sections
+             # Gen93_v0.01, 2017/06/16,  Carl, support overlapped rom sections
+             # LR12_v0.03,  2016/05/26,  Carl, avoid checking dynamic sections 
+             # LR12_v0.02,  2016/03/17,  Carl, avoid checking SIGNATURE section 
+             # LR12_v0.01,  2015/12/04,  Tero, 1st version 
+
+use strict;
+BEGIN { push @INC, './tools/MemoryUtility/' }  # add additional library path
+use SymFileParser;
+my @ex_reg = qw(ISPRAM DSPRAM CACHED_EXTSRAM_MCURO_HWRW_DRDI_);
+
+my $g_sym_file = $ARGV[0];
+my $g_exit_val = 0;
+if (!-e $g_sym_file) { die "$g_sym_file does not exist!!!\n";}
+SymFileParser::ParseSYM($g_sym_file);
+my $exe_regions =SymFileParser::ListAllExeRegion(1);
+my @regions;
+my $index=0;
+foreach my $region (@$exe_regions) {
+  foreach my $strPattern (@ex_reg) {
+    if($region =~ /$strPattern/) {
+      delete @$exe_regions[$index];
+    }
+  }
+  $index++;
+}
+foreach my $region (@$exe_regions) {
+  my $reg_begin =SymFileParser::GetExeRegionInfo($region,Region::VMA);
+  my $reg_size = SymFileParser::GetExeRegionInfo($region,Region::Size);
+  my $phy_loc = sprintf("0x%.8x",hex(get_physical_address($reg_begin)));
+  if(hex($reg_size)) {
+#    print("\tpush $region\n");
+    push @regions,[$reg_begin,$reg_size,$phy_loc,$region];
+  }
+}
+@regions = sort {$a->[0] cmp $b->[0] } @regions;
+#print("\nSections which has data:\n");
+#print("|Begin     |Length    |SRAM addr |Section name\n");
+#foreach my $reg (@regions) {
+#  print(" @$reg[0] @$reg[1] @$reg[2] @$reg[3]\n");
+#}
+print("\nCheck overlapping sections...\n");
+foreach my $reg (@regions) {
+  my $reg_begin = hex(@$reg[2]);
+  my $reg_end = $reg_begin + hex(@$reg[1])-1;
+  my ($index) = grep { $regions[$_][3] eq @$reg[3] } 0..$#regions;
+  my @sregions =();
+  push @sregions,@regions[$index..$#regions];
+  foreach my $reg_lap (@sregions) {
+    if (!(@$reg[3] eq @$reg_lap[3])) {
+      my $reg_lap_begin = hex(@$reg_lap[2]);
+      my $reg_lap_end = $reg_lap_begin+hex(@$reg_lap[1])-1;
+      if((($reg_begin > $reg_lap_begin) and ($reg_begin < $reg_lap_end)) or (($reg_end > $reg_lap_begin) and ($reg_end < $reg_lap_end))) {
+	my $begin1 = sprintf("0x%.8x",$reg_begin);
+	my $begin2 = sprintf("0x%.8x",$reg_lap_begin);
+	my $end1 = sprintf("0x%.8x",$reg_end);
+	my $end2 = sprintf("0x%.8x",$reg_lap_end);
+	if (($reg_begin < $reg_lap_begin) and ($reg_end > $reg_lap_end)) {
+	  print(" @$reg[3] ($begin1-$end1) is inside of @$reg_lap[3] ($begin2-$end2)\n");
+	  $g_exit_val = 1;
+	} elsif (($reg_begin > $reg_lap_begin) and ($reg_begin < $reg_lap_end)) {
+	  my $ol_size = $reg_lap_end - $reg_begin;
+	  $ol_size = sprintf("0x%.8x",$ol_size);
+	  print(" @$reg[3] ($begin1-$end1) begin overlaps ($ol_size) @$reg_lap[3] ($begin2-$end2)\n");
+	  $g_exit_val = 1;
+	} elsif (($reg_end > $reg_lap_begin) and ($reg_end < $reg_lap_end)) {
+	  my $ol_size = $reg_end - $reg_lap_begin;
+	  $ol_size = sprintf("0x%.8x",$ol_size);
+	  print(" @$reg[3] ($begin1-$end1) end overlaps  ($ol_size) @$reg_lap[3] ($begin2-$end2)\n");
+	  $g_exit_val = 1;
+	}
+      }
+    }
+  }
+}
+print("\nDone, check overlapping sections\n");
+exit $g_exit_val;
+
+sub get_physical_address
+  {
+    my ($str_address) = @_;
+    my $addr_mask = 0x0fffffff;
+    my $bank = hex($str_address)>>28;
+    if (($bank == 1) || ($bank == 7)) {
+      $addr_mask = 0x1fffffff;
+    }
+    return sprintf("0x%.8x",hex($str_address) & $addr_mask);
+  }