diff -r 9ca650050cf0 -r c22eff170fac imgtools/romtools/rombuild/r_rom.cpp --- a/imgtools/romtools/rombuild/r_rom.cpp Mon Nov 22 10:41:57 2010 +0800 +++ b/imgtools/romtools/rombuild/r_rom.cpp Mon Nov 22 10:56:31 2010 +0800 @@ -399,7 +399,7 @@ E32Rom::~E32Rom() { if(iSymGen){ - delete iSymGen; + SymbolGenerator::Release(); iSymGen = NULL ; } if(gLowMem) @@ -699,8 +699,6 @@ if (r!=KErrNone) { Print(EError, "LoadContents failed - return code %d\n", r); - if(iSymGen) - iSymGen->WaitThreads(); return r; } iExtensionRomHeader->iRomRootDirectoryList = dummy.iRomRootDirectoryList; @@ -708,8 +706,6 @@ iLoaderHeader->SetUp(iObey); FinaliseExtensionHeader(aKernelRom); DisplayExtensionHeader(); - if(iSymGen) - iSymGen->WaitThreads(); return KErrNone; } @@ -740,8 +736,6 @@ if (r!=KErrNone) { Print(EError, "LoadContents failed - return code %d\n", r); - if(iSymGen) - iSymGen->WaitThreads(); return r; } @@ -749,16 +743,12 @@ if(r!=KErrNone) { Print(EError, "Setup pages information failed - return code %d\n", r); - if(iSymGen) - iSymGen->WaitThreads(); return r; } r = CheckUnpagedMemSize(); // check for unpaged memory overflow if(r!=KErrNone) { - if(iSymGen) - iSymGen->WaitThreads(); return r; } @@ -766,8 +756,6 @@ if(r!=KErrNone) { Print(EError, "CompressPages failed - return code %d\n", r); - if(iSymGen) - iSymGen->WaitThreads(); return r; } @@ -795,8 +783,6 @@ TUint testCheckSum = HMem::CheckSum((TUint *)iHeader, iHeader->iRomSize); Print(ELog, "Rom 32bit words sum to %08x\n", testCheckSum); if (testCheckSum != iObey->iCheckSum){ - if(iSymGen) - iSymGen->WaitThreads(); return Print(EError, "Rom checksum is incorrect: %08x should be %08x\n", testCheckSum, iObey->iCheckSum); } @@ -836,8 +822,6 @@ } } } - if(iSymGen) - iSymGen->WaitThreads(); return KErrNone; } @@ -1325,9 +1309,9 @@ TInt fileCount=0; if(gGenSymbols && !iSymGen) { string filename(iObey->GetFileName()); - filename.erase(filename.length() - 3,3); - filename.append("symbol"); - iSymGen = new SymbolGenerator(filename.c_str(),gThreadNum - 1); + iSymGen = SymbolGenerator::GetInstance(); + iSymGen ->SetImageType(ERomImage); + iSymGen ->SetSymbolFileName(filename); } // @@ -1399,9 +1383,7 @@ mainptr->Extend(offset); iOverhead +=offset; if(iSymGen){ - SymGenContext context ; - memset(&context,0,sizeof(SymGenContext)); - iSymGen->AddEntry(context); + iSymGen->SetFinished(); } return (char*)mainptr->iImagePtr; } @@ -1454,8 +1436,7 @@ return; // first section has overflowed current->FixupRomEntries(size); if(iSymGen) { - SymGenContext context ; - memset(&context,0,sizeof(SymGenContext)); + TPlacedEntry context ; context.iFileName = current->iFileName ; context.iDataAddress = savedAddr ; iSymGen->AddEntry(context); @@ -1470,8 +1451,7 @@ iHeader->iHcrFileAddress = current->iHeaderRange.iImageAddr ; TRACE(TAREA, Print(ELog, "iHeader->iHcrFileAddress = %08x\n", iHeader->iHcrFileAddress)); if(iSymGen) { - SymGenContext context ; - memset(&context,0,sizeof(SymGenContext)); + TPlacedEntry context ; context.iFileName = current->iFileName ; context.iDataAddress = savedAddr ; iSymGen->AddEntry(context); @@ -1535,7 +1515,7 @@ LoadFileToRom(current); TRomImageHeader *header = current->iRomImageHeader; if(iSymGen){ - SymGenContext context ; + TPlacedEntry context ; context.iFileName = current->iFileName ; context.iTotalSize = section1size; context.iCodeAddress = header->iCodeAddress;