[Feature]Upload Modem source code

Change-Id: Id4294f30faced84d3e6fd6d5e61e1111bf287a37
diff --git a/mcu/tools/DSP/Parsing_DSP_array.pm b/mcu/tools/DSP/Parsing_DSP_array.pm
new file mode 100644
index 0000000..616dab4
--- /dev/null
+++ b/mcu/tools/DSP/Parsing_DSP_array.pm
@@ -0,0 +1,121 @@
+#!/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:
+#* ---------
+#*   FileInfoParser.pm
+#*
+#* Project:
+#* --------
+#*
+#*
+#* Description:
+#* ------------
+#*   This module collects the dsp bin base address and return. User: Append2.pl
+#*       
+#*
+#* Author:
+#* -------
+#*   Carl Kao (mtk08237)
+#*
+#****************************************************************************/
+use strict;
+BEGIN { push @INC, './pcore/tools/', './common/tools/MemoryUtility/' }  # add additional library path         
+use SymFileParser;
+use sysGenUtility;
+
+package Parsing_DSP_array;
+
+use constant L1DSP_BIN      => "DSP_TEMP_ROM_SPACE";
+use constant L1DSP_SIZE    => (14*1024*1024);     # hardcode size 14MB, control by DSP bin owner
+use constant MD_MAX_SIZE    => (480*1024*1024);  # max MD s
+
+
+my $VERNO = " Gen93_v0.01";
+            # Gen93_v0.02 , 2016/Dec/19,  Add L1DSP_SIZE for DSP to control DSP size
+            # Gen93_v0.01 , 2016/Nov/21,  Re-factor return info. for DSP space
+            # u0.03 , 2015/01/19,  Memory Utility Refinement
+            # u0.02 , 2014/11/03,  Return 0xCDCDCDAA for pcore only load
+            # u0.01 , 2014/10/29,  Initial revision
+
+sub getDSPsymbol
+{
+
+my $MAIN_SYM_FILE = shift;
+my $PLATFORM_NAME = shift;
+my $C2K_MODE_SUPPORT = shift;
+my $INFO_MAKE_FILE = shift;
+my $FS_RAMDISK = shift;
+
+    # disable in LR12, backup for other condition
+    #        if(BuildInfo::exist(BuildOPT::CMPL, "__PC ORE_ONLY__"))  
+    #        {
+    #            print "it is pcore only load!\n";
+    #            return (0xCDCDCDAA, 0x0);
+    #        }
+
+    SymFileParser::ParseSYM($MAIN_SYM_FILE);
+
+    my $nL1dspBase  = hex(SymFileParser::GetLinkerSymbolAddress(L1DSP_BIN, LinkerSymPostfix::Base, LinkerSymPrefix::None));
+    # Give the EMI physical address offset
+	if (($PLATFORM_NAME eq "MT6880" or $PLATFORM_NAME eq "MT6890" or $PLATFORM_NAME eq "MT2735")) {
+    	if ($FS_RAMDISK eq "TRUE"){
+            $nL1dspBase -= 0x8000000;
+        } else {
+            if ($C2K_MODE_SUPPORT eq "NONE"){
+                $nL1dspBase -= 0xE000000;
+            } elsif ($C2K_MODE_SUPPORT ne "NONE") {
+                $nL1dspBase -= 0xA000000;
+            }
+    	}
+	}
+
+    if (undef != $nL1dspBase) {
+        $nL1dspBase -= (&sysUtil::GetCacheablePrefix()) if ($nL1dspBase >= &sysUtil::GetCacheablePrefix());
+            
+        my $nL1dspSize = hex(SymFileParser::GetLinkerSymbolAddress(L1DSP_BIN, LinkerSymPostfix::Length, LinkerSymPrefix::None));
+
+        #print "L1 DSP ZI: base = ".CommonUtil::Dec2Hex($nL1dspBase).", size = ".CommonUtil::Dec2Hex($nL1dspSize)."\n";
+        if($nL1dspBase + $nL1dspSize > MD_MAX_SIZE) {
+                &sysUtil::sysgen_die("L1 DSP ZI: base(".CommonUtil::Dec2Hex($nL1dspBase).") + size(".CommonUtil::Dec2Hex($nL1dspSize).") > (".MD_MAX_SIZE.")\n", __FILE__, __LINE__);
+        }
+        return ($nL1dspBase, $nL1dspSize);
+    } else {
+        return (0xCDCDCDAA, 0x0);
+    }
+}
+
+
diff --git a/mcu/tools/DSP/PcoreUpdateDSPAddress.pl b/mcu/tools/DSP/PcoreUpdateDSPAddress.pl
new file mode 100644
index 0000000..6e36ab7
--- /dev/null
+++ b/mcu/tools/DSP/PcoreUpdateDSPAddress.pl
@@ -0,0 +1,200 @@
+#!/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:
+#* ---------
+#*   PcoreUpdateDSPAddress.pl
+#*
+#* Project:
+#* --------
+#*
+#*
+#* Description:
+#* ------------
+#*   This script is used to modify elf file for share buffer mechanism
+#* 
+#*
+#* Author:
+#* -------
+#*   Carl Kao (mtk08237)
+#*
+#*------------------------------------------------------------------------------
+#* Upper this line, this part is controlled by PVCS VM. DO NOT MODIFY!!
+#*============================================================================
+#****************************************************************************/
+#****************************************************************************
+# Included Modules
+#****************************************************************************
+use strict;
+BEGIN { push @INC, './pcore/tools/', './common/tools/MemoryUtility/' }  # add additional library path
+use SymFileParser;  #tools of pcore
+
+
+#****************************************************************************
+# Constants
+#****************************************************************************
+my $PCORE_UPDATE_DSP_ADDRESS_VERNO     = " v0.03";
+                                         # v0.03 , 2015/06/18,  Refine error message for avoid false alarm in EWS build
+                                         # v0.02 , 2015/01/19,  Memory Utility Refinement
+                                         # v0.01 , 2014/07/18,  Initial revision
+
+#****************************************************************************
+# Input
+#****************************************************************************
+my $PCORE_SYM_FILE      = $ARGV[0];
+my $PCORE_ELF_FILE      = $ARGV[1];
+my $L1CORE_SYM_FILE     = $ARGV[2];
+my $BM_NEW              = $ARGV[3];
+
+print "Input:\n";
+print map{ "\t".$_."\n" } @ARGV ;
+
+
+#****************************************************************************
+# Variable for configuation
+#****************************************************************************
+my $strPcoreSymbolName  = "g_dsp_bin_ptr";
+my $strL1coreSymbolName = "dsp_bin";
+
+
+#****************************************************************************
+# >>>  Main Flow
+#****************************************************************************
+# fix build error for MIPS
+exit 0;
+
+# add below checking for avoid false alarm in EWS build
+&CheckParamForEWS();
+
+# 1. parsing L1CORE SYM "first"
+SymFileParser::ParseSYM($L1CORE_SYM_FILE);
+my $l1coreSymbolRef = SymFileParser::GetSymbol();
+my $nl1coreDSPSectionAddr = hex(@{$l1coreSymbolRef->{$strL1coreSymbolName}}[Symbol::Addr]);
+
+pcoreUpdateDSPSection_die("[1.0] LCORE variable not exist", __FILE__, __LINE__) if( $nl1coreDSPSectionAddr == undef );
+
+
+
+# 2. then parsing PCORE SYM FIRST
+SymFileParser::ParseSYM($PCORE_SYM_FILE);
+my $pcoreSymbolRef = SymFileParser::GetSymbol();
+my $nPcorePtrAddr = hex(@{$pcoreSymbolRef->{$strPcoreSymbolName}}[Symbol::Addr]);
+
+pcoreUpdateDSPSection_die("[2.0] PCORE variable not exist", __FILE__, __LINE__) if( $nPcorePtrAddr == undef );
+
+
+
+# 3. get section info
+my $strPcoreSymSection = "ROM";
+my $nPcoreSymSectionVMA    = hex(SymFileParser::GetExeRegionInfo($strPcoreSymSection, Region::VMA));
+my $nPcoreSymSectionOffset = hex(SymFileParser::GetExeRegionInfo($strPcoreSymSection, Region::Offsets));
+
+
+
+# 4. update l1core symbol address to pcore elf
+my $nAddrInElf = $nPcorePtrAddr + ($nPcoreSymSectionOffset - $nPcoreSymSectionVMA);
+ModifyElf($nAddrInElf, $nl1coreDSPSectionAddr);
+printf("strPcoreSymbolName:\t%s,\tnl1coreDSPSectionAddr:\t0x%.8x\n", $strPcoreSymbolName, $nl1coreDSPSectionAddr);
+printf("strL1coreSymbolName:\t%s,\tnPcorePtrAddr:\t0x%.8x\n", $strL1coreSymbolName, $nPcorePtrAddr);
+printf("nPcoreSymSectionVMA:\t0x%.8x,\tnAddrInElf:\t0x%.8x\n", $nPcoreSymSectionVMA, $nAddrInElf);
+
+exit 0;
+
+#****************************************************************************
+# Subroutines
+#****************************************************************************
+sub ModifyElf
+{
+    my ($ModifyAddr, $nModifyValue) = (@_);
+    my $buffer;
+
+    open (FILE_HANDLE, "+<$PCORE_ELF_FILE") or &ReadElf_die("[2.0]$PCORE_ELF_FILE: file error!", __FILE__, __LINE__);
+    binmode FILE_HANDLE;
+    seek FILE_HANDLE,$ModifyAddr,0;
+    $buffer = pack("L", $nModifyValue);
+    print FILE_HANDLE $buffer;
+}
+
+
+#---------------------------------------------------------------------
+
+
+sub pcoreUpdateDSPSection_die
+{
+    my ($error_msg, $file, $line_no) = @_;
+    my $pack_name = undef;
+    if(!defined $file or !defined $line_no)
+    {
+        ($pack_name, $file, $line_no) = caller;    
+    }
+	&CommonUtil::error_handler($error_msg, $file, $line_no, 'PCORE_DSP_SECTION_UPDATE'); 
+}
+
+
+#---------------------------------------------------------------------
+
+
+sub CheckParam
+{
+    my ($stage, $file, $checkCore) = @_;
+    
+    if(!(defined $file and -e $file))
+    {
+        if($BM_NEW ne "bm_new")
+        {
+            &pcoreUpdateDSPSection_die("[Parameter $stage] $file doesn't exist. \"Please fix $checkCore build error (check error message in log folder) to avoid this error!\"", __FILE__, __LINE__)
+        }
+        else
+        {
+            print("[Parameter $stage] $file doesn't exist. \"Please fix $checkCore build error (check error message in log folder) to avoid this build check!\"", __FILE__, __LINE__);
+            exit 0;
+        }
+    }
+}
+
+
+#---------------------------------------------------------------------
+
+
+sub CheckParamForEWS
+{
+		my $count = 1;
+
+    &CheckParam($count++, $PCORE_SYM_FILE, "Pcore");
+    &CheckParam($count++, $PCORE_ELF_FILE, "Pcore");
+    &CheckParam($count++, $L1CORE_SYM_FILE,"L1core");
+}
+