1*6777b538SAndroid Build Coastguard Worker // Copyright 2011 The Chromium Authors 2*6777b538SAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be 3*6777b538SAndroid Build Coastguard Worker // found in the LICENSE file. 4*6777b538SAndroid Build Coastguard Worker 5*6777b538SAndroid Build Coastguard Worker #include "net/base/winsock_init.h" 6*6777b538SAndroid Build Coastguard Worker 7*6777b538SAndroid Build Coastguard Worker #include <winsock2.h> 8*6777b538SAndroid Build Coastguard Worker 9*6777b538SAndroid Build Coastguard Worker #include "base/check.h" 10*6777b538SAndroid Build Coastguard Worker #include "base/lazy_instance.h" 11*6777b538SAndroid Build Coastguard Worker 12*6777b538SAndroid Build Coastguard Worker namespace { 13*6777b538SAndroid Build Coastguard Worker 14*6777b538SAndroid Build Coastguard Worker class WinsockInitSingleton { 15*6777b538SAndroid Build Coastguard Worker public: WinsockInitSingleton()16*6777b538SAndroid Build Coastguard Worker WinsockInitSingleton() { 17*6777b538SAndroid Build Coastguard Worker WORD winsock_ver = MAKEWORD(2, 2); 18*6777b538SAndroid Build Coastguard Worker WSAData wsa_data; 19*6777b538SAndroid Build Coastguard Worker bool did_init = (WSAStartup(winsock_ver, &wsa_data) == 0); 20*6777b538SAndroid Build Coastguard Worker if (did_init) { 21*6777b538SAndroid Build Coastguard Worker DCHECK(wsa_data.wVersion == winsock_ver); 22*6777b538SAndroid Build Coastguard Worker 23*6777b538SAndroid Build Coastguard Worker // The first time WSAGetLastError is called, the delay load helper will 24*6777b538SAndroid Build Coastguard Worker // resolve the address with GetProcAddress and fixup the import. If a 25*6777b538SAndroid Build Coastguard Worker // third party application hooks system functions without correctly 26*6777b538SAndroid Build Coastguard Worker // restoring the error code, it is possible that the error code will be 27*6777b538SAndroid Build Coastguard Worker // overwritten during delay load resolution. The result of the first 28*6777b538SAndroid Build Coastguard Worker // call may be incorrect, so make sure the function is bound and future 29*6777b538SAndroid Build Coastguard Worker // results will be correct. 30*6777b538SAndroid Build Coastguard Worker WSAGetLastError(); 31*6777b538SAndroid Build Coastguard Worker } 32*6777b538SAndroid Build Coastguard Worker } 33*6777b538SAndroid Build Coastguard Worker }; 34*6777b538SAndroid Build Coastguard Worker 35*6777b538SAndroid Build Coastguard Worker // Worker pool threads that use the Windows Sockets API may still be running at 36*6777b538SAndroid Build Coastguard Worker // shutdown. Leak instance and skip cleanup. 37*6777b538SAndroid Build Coastguard Worker static base::LazyInstance<WinsockInitSingleton>::Leaky 38*6777b538SAndroid Build Coastguard Worker g_winsock_init_singleton = LAZY_INSTANCE_INITIALIZER; 39*6777b538SAndroid Build Coastguard Worker 40*6777b538SAndroid Build Coastguard Worker } // namespace 41*6777b538SAndroid Build Coastguard Worker 42*6777b538SAndroid Build Coastguard Worker namespace net { 43*6777b538SAndroid Build Coastguard Worker EnsureWinsockInit()44*6777b538SAndroid Build Coastguard Workervoid EnsureWinsockInit() { 45*6777b538SAndroid Build Coastguard Worker g_winsock_init_singleton.Get(); 46*6777b538SAndroid Build Coastguard Worker } 47*6777b538SAndroid Build Coastguard Worker 48*6777b538SAndroid Build Coastguard Worker } // namespace net 49