diff chipsetsw/layer1/tools/make_cmd.pl @ 0:509db1a7b7b8

initial import: leo2moko-r1
author Space Falcon <falcon@ivan.Harhan.ORG>
date Mon, 01 Jun 2015 03:24:05 +0000
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/chipsetsw/layer1/tools/make_cmd.pl	Mon Jun 01 03:24:05 2015 +0000
@@ -0,0 +1,81 @@
+#!perl
+
+# generate a dynamic Linker command file 
+# PARAMETER ARE:
+# 1 : Name of the Linker command file
+# 2 : Name of the file with the parameter
+# 
+
+my ($cmd_file_temp,$tmp_file)=@ARGV;
+
+open (TMP, "$tmp_file");
+my $const_boot_lib = <TMP>;
+my $bss_boot_lib = <TMP>;
+my $bss_libs = <TMP>;
+my $const_libs = <TMP>;
+my $toolchoice_type = <TMP>;
+close TMP;
+
+# define the REPLACE STRINGS
+my $const_boot_str="(CONST_BOOT_LIB)";
+my $bss_boot_str="(BSS_BOOT_LIB)";
+my $bss_str="(BSS_LIBS)";
+my $const_str="(CONST_LIBS)";
+
+# define some local variables
+my $temp;
+my @CMD;
+my $line;
+
+# determine the cmd file name
+@CMD=split /.template/, $cmd_file_temp;
+$cmd_file=$CMD[0].".cmd";
+
+open (TMP1, ">$cmd_file");
+open (TMP,$cmd_file_temp);
+while ($line=<TMP>) {
+	if ($line =~ m/$const_boot_str/g) {
+		$line=mak_libs ($const_boot_lib)
+	}
+	if ($line =~ m/$bss_boot_str/g) {
+		$line=mak_libs ($bss_boot_lib)
+	}
+	if ($line =~ m/$bss_str/g) {
+		# insert the Libs
+		$line=mak_libs ($bss_libs);
+	}
+	if ($line =~ m/$const_str/g) {
+		$line=mak_libs ($const_libs)
+	}
+
+    # NEW COMPILER MANAGEMENT 
+    # If use of VISUAL LINKER, needs to manage trampoline download.
+    # Case of:
+    #      - TOOL_CHOICE == 0 => compiler v1.22e with vlinker v1.9902
+    if ($toolchoice_type == 0)  {
+        $line =~ s(COMMENT2START)();
+        $line =~ s(COMMENT2END)();    
+    }
+     
+    if ($toolchoice_type == 3)  {
+        $line =~ s(COMMENT2START)(/*);
+        $line =~ s(COMMENT2END)(*/);
+    }
+
+	print TMP1 $line;
+}
+close TMP;
+close TMP1;
+unlink $tmp_file;
+
+sub mak_libs
+{
+	my ($bss_libs) =@_;
+	my @temp;
+	@temp = split /=/, $bss_libs;
+	$_="\t\t\t" . $temp[1];
+	s/\) /)\n\t\t\t/g;
+	$_ =~ tr /\"//d;
+	return $_;
+}
+