diff --git a/indra/newview/llmeshrepository.cpp b/indra/newview/llmeshrepository.cpp
index 9f302f9e57f2aaa456eb3d3735e8922053a57d81..3163f4f186602db3417d690bce820b7e124dbba2 100755
--- a/indra/newview/llmeshrepository.cpp
+++ b/indra/newview/llmeshrepository.cpp
@@ -1368,7 +1368,7 @@ void dumpLLSDToFile(LLSD& content, std::string& filename)
 	LLSDSerialize::toPrettyXML(content,of);
 }
 
-LLSD LLMeshUploadThread::wholeModelToLLSD(bool include_textures)
+void LLMeshUploadThread::wholeModelToLLSD(LLSD& dest, bool include_textures)
 {
 	// TODO where do textures go?
 	
@@ -1470,11 +1470,11 @@ LLSD LLMeshUploadThread::wholeModelToLLSD(bool include_textures)
 	}
 
 	result["asset_resources"] = res;
-#if 0	
+#if 1	
 	dumpLLSDToFile(result,std::string("whole_model.xml"));
 #endif
-	
-	return result;
+
+	dest = result;
 }
 
 void LLMeshUploadThread::doWholeModelUpload()
@@ -1525,7 +1525,8 @@ void LLMeshUploadThread::doWholeModelUpload()
 	}
 
 	bool do_include_textures = false; // not needed for initial cost/validation check.
-	LLSD model_data = wholeModelToLLSD(do_include_textures);
+	LLSD model_data;
+	wholeModelToLLSD(model_data, do_include_textures);
 
 	mPendingUploads++;
 	LLCurlRequest::headers_t headers;
diff --git a/indra/newview/llmeshrepository.h b/indra/newview/llmeshrepository.h
index 9d8119dc48c02bc93319d5b84f8aa444c2508251..9460c0c048615c4e69b6b0f360cde9b695112d41 100755
--- a/indra/newview/llmeshrepository.h
+++ b/indra/newview/llmeshrepository.h
@@ -425,7 +425,7 @@ class LLMeshUploadThread : public LLThread
 	void doWholeModelUpload();
 	void doIterativeUpload();
 
-	LLSD wholeModelToLLSD(bool include_textures);
+	void wholeModelToLLSD(LLSD& dest, bool include_textures);
 };
 
 class LLMeshRepository