diff --git a/.gitignore b/.gitignore
index 0b55cb00aa9136febb23c6f8fc6a1dd90fb16c68..5368cd01e9fcd1476ffa7de98b653adc529b8133 100755
--- a/.gitignore
+++ b/.gitignore
@@ -17,13 +17,7 @@ debian/files
 debian/secondlife-appearance-utility*
 debian/secondlife-viewer*
 indra/.distcc
-build-vc80/
-build-vc100/
-build-vc120/
-build-vc120-32/
-build-vc120-64/
-build-vc150-32/
-build-vc150-64/
+build-vc*
 indra/CMakeFiles
 indra/build-vc[0-9]*
 indra/lib/mono/1.0/*.dll
diff --git a/autobuild.xml b/autobuild.xml
index 9bc40a50ed16ad2c7e4f049d435e9731a7ee4162..bd8b4304f7ff4b1f17420c395d0721f4e769e4d9 100644
--- a/autobuild.xml
+++ b/autobuild.xml
@@ -1840,11 +1840,11 @@
             <key>archive</key>
             <map>
               <key>hash</key>
-              <string>3de8bf840cde51ec061ae1c12e39b620</string>
+              <string>9a13d5b3d5a4a038175461defb801963</string>
               <key>hash_algorithm</key>
               <string>md5</string>
               <key>url</key>
-              <string>https://pkg.alchemyviewer.org/repository/autobuild-external/tmpanext/libwebp-1.1.0.200900053-windows-200900053.tar.bz2</string>
+              <string>https://pkg.alchemyviewer.org/repository/autobuild-external/libwebp/windows/libwebp-1.1.0.304-windows-304.tar.bz2</string>
             </map>
             <key>name</key>
             <string>windows</string>
@@ -1854,18 +1854,18 @@
             <key>archive</key>
             <map>
               <key>hash</key>
-              <string>0063c0a3053b222014b6bec37a1311d4</string>
+              <string>85c1623e1d7bdf36cc3c7eb937749ea7</string>
               <key>hash_algorithm</key>
               <string>md5</string>
               <key>url</key>
-              <string>https://pkg.alchemyviewer.org/repository/autobuild-external/tmpanext/libwebp-1.1.0.200900052-windows64-200900052.tar.bz2</string>
+              <string>https://pkg.alchemyviewer.org/repository/autobuild-external/libwebp/windows64/libwebp-1.1.0.304-windows64-304.tar.bz2</string>
             </map>
             <key>name</key>
             <string>windows64</string>
           </map>
         </map>
         <key>version</key>
-        <string>1.1.0.202202257</string>
+        <string>1.1.0.304</string>
       </map>
       <key>libxml2</key>
       <map>
@@ -2610,9 +2610,11 @@ Copyright (c) 2012, 2014, 2015, 2016 nghttp2 contributors</string>
             <key>archive</key>
             <map>
               <key>hash</key>
-              <string>222a406ecb4071a9cc9635353afa337e</string>
+              <string>708d1abea051d34a8c40290bb052393e</string>
+              <key>hash_algorithm</key>
+              <string>md5</string>
               <key>url</key>
-              <string>http://automated-builds-secondlife-com.s3.amazonaws.com/ct2/54977/511775/openjpeg-1.5.1.538970-windows-538970.tar.bz2</string>
+              <string>https://pkg.alchemyviewer.org/repository/autobuild-external/openjpeg/windows/openjpeg-1.5.1.309-windows-309.tar.bz2</string>
             </map>
             <key>name</key>
             <string>windows</string>
@@ -2622,18 +2624,18 @@ Copyright (c) 2012, 2014, 2015, 2016 nghttp2 contributors</string>
             <key>archive</key>
             <map>
               <key>hash</key>
-              <string>07cff9eafaecfbe6f44e2a05b3465cae</string>
+              <string>590b392ce88b34645f6068e4a02ea44f</string>
               <key>hash_algorithm</key>
               <string>md5</string>
               <key>url</key>
-              <string>https://pkg.alchemyviewer.org/repository/autobuild-external/tmpanext/openjpeg-1.5.1.200900057-windows64-200900057.tar.bz2</string>
+              <string>https://pkg.alchemyviewer.org/repository/autobuild-external/openjpeg/windows64/openjpeg-1.5.1.309-windows64-309.tar.bz2</string>
             </map>
             <key>name</key>
             <string>windows64</string>
           </map>
         </map>
         <key>version</key>
-        <string>1.5.1</string>
+        <string>1.5.1.309</string>
       </map>
       <key>openssl</key>
       <map>
@@ -3663,7 +3665,7 @@ Copyright (c) 2012, 2014, 2015, 2016 nghttp2 contributors</string>
         <key>windows</key>
         <map>
           <key>build_directory</key>
-          <string>build-vc${AUTOBUILD_VSVER|150}-$AUTOBUILD_ADDRSIZE</string>
+          <string>build-vc-$AUTOBUILD_ADDRSIZE</string>
           <key>configurations</key>
           <map>
             <key>RelWithDebInfo</key>
diff --git a/indra/cmake/00-Common.cmake b/indra/cmake/00-Common.cmake
index 061be9c358d554ce1fdf8bd32b6c9182bc9c2a32..5f244f5b8fa0d6ee6a07072ffbec2f72b0b97c6c 100644
--- a/indra/cmake/00-Common.cmake
+++ b/indra/cmake/00-Common.cmake
@@ -180,6 +180,11 @@ if (WINDOWS)
       /DBOOST_CONFIG_SUPPRESS_OUTDATED_MESSAGE
       )
 
+  # library linkage defines
+  add_definitions(
+      /DWEBP_DLL
+  )
+
   if("${CMAKE_CXX_COMPILER_ID}" MATCHES "Clang")
     add_definitions(-DBOOST_USE_WINDOWS_H)
   endif()
diff --git a/indra/cmake/Copy3rdPartyLibs.cmake b/indra/cmake/Copy3rdPartyLibs.cmake
index a37ebd193b9e79aeac5326c3e5857ae2b563a196..49a10c512475528fa28abc7638f23b303e122b1f 100644
--- a/indra/cmake/Copy3rdPartyLibs.cmake
+++ b/indra/cmake/Copy3rdPartyLibs.cmake
@@ -62,6 +62,7 @@ if(WINDOWS)
         glod.dll
         libhunspell.dll
         epoxy-0.dll
+        libwebp.dll
         )
 
     # Filenames are different for 32/64 bit BugSplat file and we don't
diff --git a/indra/cmake/WebP.cmake b/indra/cmake/WebP.cmake
index 6105b10d55c05daa823059bd9306a8c975ed01dd..3795cec31320c08e3365150595cd59f5022b16df 100644
--- a/indra/cmake/WebP.cmake
+++ b/indra/cmake/WebP.cmake
@@ -9,7 +9,10 @@ if (USESYSTEMLIBS)
 else (USESYSTEMLIBS)
   use_prebuilt_binary(libwebp)
   if (WINDOWS)
-    set(WEBP_LIBRARIES libwebp)
+    set(WEBP_LIBRARIES 
+        debug libwebp_debug_dll
+        optimized libwebp_dll
+        )
     set(WEBP_INCLUDE_DIRS ${LIBS_PREBUILT_DIR}/include/webp)
   elseif(DARWIN)
     set(WEBP_LIBRARIES webp)
diff --git a/indra/llcommon/is_approx_equal_fraction.h b/indra/llcommon/is_approx_equal_fraction.h
index 4a9b2e2725f58bfc69b65cc1a01d702855a926d9..6a567c78cb2fa7c9e582bdeae15ccf0e0ebe0d66 100644
--- a/indra/llcommon/is_approx_equal_fraction.h
+++ b/indra/llcommon/is_approx_equal_fraction.h
@@ -49,7 +49,7 @@ inline BOOL is_approx_equal_fraction_impl(FTYPE x, FTYPE y, U32 frac_bits)
     FTYPE diff = (FTYPE) fabs(x - y);
 
     S32 diffInt = (S32) diff;
-    S32 diffFracTolerance = (S32) ((diff - (FTYPE) diffInt) * (1 << frac_bits));
+    S32 diffFracTolerance = (S32) ((diff - (FTYPE) diffInt) * (1U << frac_bits));
 
     // if integer portion is not equal, not enough bits were used for packing
     // so error out since either the use case is not correct OR there is
diff --git a/indra/llcommon/llsdserialize.cpp b/indra/llcommon/llsdserialize.cpp
index 94d1141e1fa35249d5f75a4907546554a4994019..22b24a06b4f644078a83997d306914c9f3f4ef99 100644
--- a/indra/llcommon/llsdserialize.cpp
+++ b/indra/llcommon/llsdserialize.cpp
@@ -1296,15 +1296,16 @@ S32 LLSDNotationFormatter::format_impl(const LLSD& data, std::ostream& ostr,
 		}
 
 		bool need_comma = false;
-		std::map<std::string, LLSD> sorted_map(data.beginMap(), data.endMap());
-		for(const auto& out_pair : sorted_map)
+		LLSD::map_const_iterator iter = data.beginMap();
+		LLSD::map_const_iterator end = data.endMap();
+		for(; iter != end; ++iter)
 		{
 			if(need_comma) ostr << ",";
 			need_comma = true;
 			ostr << post << inner_pre << '\'';
-			serialize_string(out_pair.first, ostr);
+			serialize_string((*iter).first, ostr);
 			ostr << "':";
-			format_count += format_impl(out_pair.second, ostr, options, level + 2);
+			format_count += format_impl((*iter).second, ostr, options, level + 2);
 		}
 		ostr << post << pre << "}";
 		break;
@@ -1452,12 +1453,13 @@ S32 LLSDBinaryFormatter::format_impl(const LLSD& data, std::ostream& ostr,
 		ostr.put('{');
 		U32 size_nbo = htonl(data.size());
 		ostr.write((const char*)(&size_nbo), sizeof(U32));
-		std::map<std::string, LLSD> sorted_map(data.beginMap(), data.endMap());
-		for (const auto& out_pair : sorted_map)
+		LLSD::map_const_iterator iter = data.beginMap();
+		LLSD::map_const_iterator end = data.endMap();
+		for(; iter != end; ++iter)
 		{
 			ostr.put('k');
-			formatString(out_pair.first, ostr);
-			format_count += format_impl(out_pair.second, ostr, options, level+1);
+			formatString((*iter).first, ostr);
+			format_count += format_impl((*iter).second, ostr, options, level+1);
 		}
 		ostr.put('}');
 		break;
diff --git a/indra/llcommon/llsdserialize_xml.cpp b/indra/llcommon/llsdserialize_xml.cpp
index e3289fafeb781deddc664c184107e5d2642a3dfb..4a6a4a02fa699904cb6d0cdff347d22b32ffae7b 100644
--- a/indra/llcommon/llsdserialize_xml.cpp
+++ b/indra/llcommon/llsdserialize_xml.cpp
@@ -96,11 +96,12 @@ S32 LLSDXMLFormatter::format_impl(const LLSD& data, std::ostream& ostr,
 		else
 		{
 			ostr << pre << "<map>" << post;
-			std::map<std::string, LLSD> sorted_map(data.beginMap(), data.endMap());
-			for(const auto& out_pair : sorted_map)
+			LLSD::map_const_iterator iter = data.beginMap();
+			LLSD::map_const_iterator end = data.endMap();
+			for(; iter != end; ++iter)
 			{
-				ostr << pre << "<key>" << escapeString(out_pair.first) << "</key>" << post;
-				format_count += format_impl(out_pair.second, ostr, options, level + 1);
+				ostr << pre << "<key>" << escapeString((*iter).first) << "</key>" << post;
+				format_count += format_impl((*iter).second, ostr, options, level + 1);
 			}
 			ostr << pre <<  "</map>" << post;
 		}
diff --git a/indra/llui/lldockcontrol.cpp b/indra/llui/lldockcontrol.cpp
index bd42497cb66b8957f7a07bd3df7d3e0a1a03a508..7ef2b9822ce10525666f93652182a1e225c87927 100644
--- a/indra/llui/lldockcontrol.cpp
+++ b/indra/llui/lldockcontrol.cpp
@@ -74,6 +74,8 @@ LLDockControl::LLDockControl(LLView* dockWidget, LLFloater* dockableFloater,
 	{
 		mDockWidgetVisible = false;
 	}
+
+	mNonToolbarPanelHandle = dockableFloater->getRootView()->getChild<LLView>("non_toolbar_panel")->getHandle();
 }
 
 LLDockControl::~LLDockControl()
@@ -97,7 +99,10 @@ void LLDockControl::setDock(LLView* dockWidget)
 
 void LLDockControl::getAllowedRect(LLRect& rect)
 {
-	rect = mDockableFloater->getRootView()->getChild<LLView>("non_toolbar_panel")->getRect();
+	if (!mNonToolbarPanelHandle.isDead())
+	{
+		rect = mNonToolbarPanelHandle.get()->getRect();
+	}
 }
 
 void LLDockControl::repositionDockable()
diff --git a/indra/llui/lldockcontrol.h b/indra/llui/lldockcontrol.h
index 98a9c7236d79ca9788cee21ba55f7933d55331f9..140e82fbdf8990bdbf1aebf0dd9c8dfc6d4f5a30 100644
--- a/indra/llui/lldockcontrol.h
+++ b/indra/llui/lldockcontrol.h
@@ -84,6 +84,7 @@ class LLDockControl
 	bool mDockWidgetVisible;
 	DocAt mDockAt;
 	LLHandle<LLView> mDockWidgetHandle;
+	LLHandle<LLView> mNonToolbarPanelHandle;
 	LLRect mPrevDockRect;
 	LLRect mRootRect;
 	LLRect mFloaterRect;
diff --git a/indra/newview/viewer_manifest.py b/indra/newview/viewer_manifest.py
index d46c774e5659f9f901d8369a027631130f70001b..277b38c48a379fe152dadf09ee1afff9e905078e 100755
--- a/indra/newview/viewer_manifest.py
+++ b/indra/newview/viewer_manifest.py
@@ -529,6 +529,8 @@ def construct(self):
             # For OpenGL extensions
             self.path("epoxy-0.dll")
 
+            self.path("libwebp.dll")
+
             # SLVoice executable
             with self.prefix(src=os.path.join(pkgdir, 'bin', 'release')):
                 self.path("SLVoice.exe")