 fe14b970ac
			
		
	
	fe14b970ac
	
	
	
		
			
			- Basically I just ran the thread tests many many times on a busy machine and bumped the timeouts whenever I hit a test failure. - This is obviously subpar, but is the best I can do without the tests being rewritten to not depend on arbitrary timeouts. git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@174721 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			51 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			51 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| //===----------------------------------------------------------------------===//
 | |
| //
 | |
| //                     The LLVM Compiler Infrastructure
 | |
| //
 | |
| // This file is dual licensed under the MIT and the University of Illinois Open
 | |
| // Source Licenses. See LICENSE.TXT for details.
 | |
| //
 | |
| //===----------------------------------------------------------------------===//
 | |
| 
 | |
| // <mutex>
 | |
| 
 | |
| // class mutex;
 | |
| 
 | |
| // bool try_lock();
 | |
| 
 | |
| #include <mutex>
 | |
| #include <thread>
 | |
| #include <cstdlib>
 | |
| #include <cassert>
 | |
| 
 | |
| std::mutex m;
 | |
| 
 | |
| typedef std::chrono::system_clock Clock;
 | |
| typedef Clock::time_point time_point;
 | |
| typedef Clock::duration duration;
 | |
| typedef std::chrono::milliseconds ms;
 | |
| typedef std::chrono::nanoseconds ns;
 | |
| 
 | |
| void f()
 | |
| {
 | |
|     time_point t0 = Clock::now();
 | |
|     assert(!m.try_lock());
 | |
|     assert(!m.try_lock());
 | |
|     assert(!m.try_lock());
 | |
|     while(!m.try_lock())
 | |
|         ;
 | |
|     time_point t1 = Clock::now();
 | |
|     m.unlock();
 | |
|     ns d = t1 - t0 - ms(250);
 | |
|     assert(d < ms(200));  // within 200ms
 | |
| }
 | |
| 
 | |
| int main()
 | |
| {
 | |
|     m.lock();
 | |
|     std::thread t(f);
 | |
|     std::this_thread::sleep_for(ms(250));
 | |
|     m.unlock();
 | |
|     t.join();
 | |
| }
 |