Updating release text and product version
authorjascui
Wed, 17 Nov 2010 13:45:48 +0800
changeset 689 b70d8ea6cf75
parent 688 27f7c5c966fc (current diff)
parent 685 39f7ecf8fbc7 (diff)
child 690 c67de7b29582
Updating release text and product version
e32tools/elf2e32/group/release.txt
--- a/e32tools/elf2e32/group/release.txt	Wed Nov 17 13:39:51 2010 +0800
+++ b/e32tools/elf2e32/group/release.txt	Wed Nov 17 13:45:48 2010 +0800
@@ -6,8 +6,8 @@
 
 version 2.2 build(7)
 ===============
-Released by Jason Cui, 17/11/2010
-	1) [RC] Failure ou1cimx1#612374 created : elf2e32.exe puts wrong name in library .dso file
+Released by Marvin Shi, 26/10/2010
+	1) Bug3494 elf2e32 treatment of ARM$$INIT_ARRAY$$Base can break GCCE builds
 
 version 2.2 build(6)
 ===============
--- a/e32tools/elf2e32/source/pl_elfexecutable.cpp	Wed Nov 17 13:39:51 2010 +0800
+++ b/e32tools/elf2e32/source/pl_elfexecutable.cpp	Wed Nov 17 13:45:48 2010 +0800
@@ -1438,7 +1438,7 @@
 
 	try {
 
-		bool limitSymbolFound = false;
+		bool specialSymbolFound = false;
 
 		// If Symbol is absolute then assume it came from linker and is a
 		// limit symbol.
@@ -1448,19 +1448,21 @@
 		}
 		else
 		{
+			// does the symbol point to the address after the end of the code or data segments?
 			if( (iCodeSegmentHdr && aSym->st_value == (iCodeSegmentHdr->p_vaddr + iCodeSegmentHdr->p_memsz)) ||
 				(iDataSegmentHdr && aSym->st_value == (iDataSegmentHdr->p_vaddr + iDataSegmentHdr->p_memsz)) )
 			{
-				//If Symbol is a $$Limit symbol, then consider the open boundary.
-				String limitstr = iStringTable + aSym->st_name;
-				if (limitstr.rfind("$$Limit",limitstr.length()) != String::npos)
+				//If Symbol contains $$, it is linker generated so consider the open boundary.
+ 				//e.g. SHT$$INIT_ARRAY$$Limit and sometimes SHT$$INIT_ARRAY$$Base 
+ 				String aSymstr = iStringTable + aSym->st_name;
+ 				if (aSymstr.rfind("$$",aSymstr.length()) != String::npos)
 				{
 					aHdr = SegmentFromAbs(aSym->st_value);
-					limitSymbolFound = true;
+					specialSymbolFound = true;
 				}
 			}
 
-			if(!limitSymbolFound )
+			if(!specialSymbolFound )
 			{
 				aHdr = Segment(aSym->st_value);
 			}