mirror of git://gcc.gnu.org/git/gcc.git
				
				
				
			2009-02-09 Benjamin Kosnik <bkoz@redhat.com>
* include/std/condition_variable (condition_variable): Remove _M_internal_mutex. Add private __native_type typedef. * src/condition_variable.cc (condition_variable::notify_one): Remove _M_internal_mutex use. Use typedef. (condition_variable::notify_all): Same. * include/std/mutex (mutex): Add private __native_type typedef. Use it. (recursive_mutex): Same. (timed_mutex): Same. (recursive_timed_mutex): Same. (once_flag): Make __native_type typedef private. * include/std/thread (this_thread): Add minimal markup. * testsuite/30_threads/condition_variable_any/cons/assign_neg.cc: Adjust line numbers. * testsuite/30_threads/condition_variable_any/cons/copy_neg.cc: Same. * testsuite/30_threads/mutex/cons/assign_neg.cc: Same. * testsuite/30_threads/mutex/cons/copy_neg.cc: Same. * testsuite/30_threads/timed_mutex/cons/assign_neg.cc: Same. * testsuite/30_threads/timed_mutex/cons/copy_neg.cc: Same. * testsuite/30_threads/thread/cons/assign_neg.cc: Same. * testsuite/30_threads/thread/cons/copy_neg.cc: Same. * testsuite/30_threads/recursive_mutex/cons/assign_neg.cc: Same. * testsuite/30_threads/recursive_mutex/cons/copy_neg.cc: Same. * testsuite/30_threads/condition_variable/cons/assign_neg.cc: Same. * testsuite/30_threads/condition_variable/cons/copy_neg.cc: Same. * testsuite/30_threads/recursive_timed_mutex/cons/assign_neg.cc: Same. * testsuite/30_threads/recursive_timed_mutex/cons/copy_neg.cc: Same. * testsuite/util/thread/all.h: Testsuite utilities for testing thread. * testsuite/30_threads/condition_variable_any/native_handle/ typesizes.cc: New. * testsuite/30_threads/mutex/native_handle/typesizes.cc: Same. * testsuite/30_threads/timed_mutex/native_handle/typesizes.cc: Same. * testsuite/30_threads/thread/native_handle/typesizes.cc: Same. * testsuite/30_threads/recursive_mutex/native_handle/typesizes.cc: Same. * testsuite/30_threads/condition_variable/native_handle/ typesizes.cc: Same. * testsuite/30_threads/recursive_timed_mutex/native_handle/ typesizes.cc: Same. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@144053 138bc75d-0d04-0410-961f-82ee72b054a4
This commit is contained in:
		
							parent
							
								
									1bcbf21afd
								
							
						
					
					
						commit
						20deb9d4d2
					
				|  | @ -1,3 +1,46 @@ | |||
| 2009-02-09  Benjamin Kosnik  <bkoz@redhat.com> | ||||
| 
 | ||||
| 	* include/std/condition_variable (condition_variable): Remove | ||||
| 	_M_internal_mutex. Add private __native_type typedef. | ||||
| 	* src/condition_variable.cc (condition_variable::notify_one): | ||||
| 	Remove _M_internal_mutex use. Use typedef. | ||||
| 	(condition_variable::notify_all): Same. | ||||
| 	* include/std/mutex (mutex): Add private __native_type typedef. Use it. | ||||
| 	(recursive_mutex): Same. | ||||
| 	(timed_mutex): Same. | ||||
| 	(recursive_timed_mutex): Same. | ||||
| 	(once_flag): Make __native_type typedef private. | ||||
| 
 | ||||
| 	* include/std/thread (this_thread): Add minimal markup. | ||||
| 
 | ||||
| 	* testsuite/30_threads/condition_variable_any/cons/assign_neg.cc: | ||||
| 	Adjust line numbers. | ||||
| 	* testsuite/30_threads/condition_variable_any/cons/copy_neg.cc: Same. | ||||
| 	* testsuite/30_threads/mutex/cons/assign_neg.cc: Same. | ||||
| 	* testsuite/30_threads/mutex/cons/copy_neg.cc: Same. | ||||
| 	* testsuite/30_threads/timed_mutex/cons/assign_neg.cc: Same. | ||||
| 	* testsuite/30_threads/timed_mutex/cons/copy_neg.cc: Same. | ||||
| 	* testsuite/30_threads/thread/cons/assign_neg.cc: Same. | ||||
| 	* testsuite/30_threads/thread/cons/copy_neg.cc: Same. | ||||
| 	* testsuite/30_threads/recursive_mutex/cons/assign_neg.cc: Same. | ||||
| 	* testsuite/30_threads/recursive_mutex/cons/copy_neg.cc: Same. | ||||
| 	* testsuite/30_threads/condition_variable/cons/assign_neg.cc: Same. | ||||
| 	* testsuite/30_threads/condition_variable/cons/copy_neg.cc: Same. | ||||
| 	* testsuite/30_threads/recursive_timed_mutex/cons/assign_neg.cc: Same. | ||||
| 	* testsuite/30_threads/recursive_timed_mutex/cons/copy_neg.cc: Same. | ||||
| 
 | ||||
| 	* testsuite/util/thread/all.h: Testsuite utilities for testing thread. | ||||
| 	* testsuite/30_threads/condition_variable_any/native_handle/ | ||||
| 	typesizes.cc: New. | ||||
| 	* testsuite/30_threads/mutex/native_handle/typesizes.cc: Same. | ||||
| 	* testsuite/30_threads/timed_mutex/native_handle/typesizes.cc: Same. | ||||
| 	* testsuite/30_threads/thread/native_handle/typesizes.cc: Same. | ||||
| 	* testsuite/30_threads/recursive_mutex/native_handle/typesizes.cc: Same. | ||||
| 	* testsuite/30_threads/condition_variable/native_handle/ | ||||
| 	typesizes.cc: Same. | ||||
| 	* testsuite/30_threads/recursive_timed_mutex/native_handle/ | ||||
| 	typesizes.cc: Same. | ||||
| 
 | ||||
| 2009-02-09  Jack Howarth  <howarth@bromo.med.uc.edu> | ||||
| 
 | ||||
| 	PR testsuite/33300 | ||||
|  |  | |||
|  | @ -1,6 +1,6 @@ | |||
| // <condition_variable> -*- C++ -*- | ||||
| 
 | ||||
| // Copyright (C) 2008 Free Software Foundation, Inc. | ||||
| // Copyright (C) 2008, 2009 Free Software Foundation, Inc. | ||||
| // | ||||
| // This file is part of the GNU ISO C++ Library.  This library is free | ||||
| // software; you can redistribute it and/or modify it under the | ||||
|  | @ -50,10 +50,12 @@ namespace std | |||
|   /// condition_variable | ||||
|   class condition_variable | ||||
|   { | ||||
|     typedef chrono::system_clock __clock_t; | ||||
|     typedef chrono::system_clock	__clock_t; | ||||
|     typedef __gthread_cond_t		__native_type; | ||||
|     __native_type			_M_cond; | ||||
| 
 | ||||
|   public: | ||||
|     typedef __gthread_cond_t* native_handle_type; | ||||
|     typedef __native_type* 		native_handle_type; | ||||
| 
 | ||||
|     condition_variable(); | ||||
|     ~condition_variable(); | ||||
|  | @ -104,8 +106,8 @@ namespace std | |||
| 		 const chrono::time_point<_Clock, _Duration>& __atime, | ||||
| 		 _Predicate __p) | ||||
|       { | ||||
| 	while(!__p()) | ||||
| 	  if(!wait_until(__lock, __atime)) | ||||
| 	while (!__p()) | ||||
| 	  if (!wait_until(__lock, __atime)) | ||||
| 	    return __p(); | ||||
| 	 | ||||
| 	return true; | ||||
|  | @ -129,9 +131,6 @@ namespace std | |||
|     { return &_M_cond; } | ||||
| 
 | ||||
|   private: | ||||
|     __gthread_cond_t _M_cond; | ||||
|     mutex _M_internal_mutex; | ||||
| 
 | ||||
|     template<typename _Clock, typename _Duration> | ||||
|       bool | ||||
|       __wait_until_impl(unique_lock<mutex>& __lock, | ||||
|  | @ -160,8 +159,11 @@ namespace std | |||
|   // Like above, only mutex may not have try_lock. | ||||
|   class condition_variable_any | ||||
|   { | ||||
|     typedef __gthread_cond_t		__native_type; | ||||
|     __native_type			_M_cond; | ||||
| 
 | ||||
|   public: | ||||
|     typedef __gthread_cond_t* native_handle_type; | ||||
|     typedef __native_type* 		native_handle_type; | ||||
| 
 | ||||
|     condition_variable_any(); | ||||
|     ~condition_variable_any(); | ||||
|  | @ -208,9 +210,6 @@ namespace std | |||
|     native_handle_type  | ||||
|     native_handle() | ||||
|     { return &_M_cond; } | ||||
| 
 | ||||
|   private: | ||||
|     __gthread_cond_t _M_cond; | ||||
|   }; | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -59,14 +59,17 @@ namespace std | |||
|   /// mutex | ||||
|   class mutex | ||||
|   { | ||||
|     typedef __gthread_mutex_t			__native_type; | ||||
|     __native_type  _M_mutex; | ||||
| 
 | ||||
|   public: | ||||
|     typedef __gthread_mutex_t* native_handle_type; | ||||
|     typedef __native_type* 			native_handle_type; | ||||
| 
 | ||||
|     mutex() | ||||
|     { | ||||
|       // XXX EAGAIN, ENOMEM, EPERM, EBUSY(may), EINVAL(may) | ||||
| #ifdef __GTHREAD_MUTEX_INIT | ||||
|       __gthread_mutex_t __tmp = __GTHREAD_MUTEX_INIT; | ||||
|       __native_type __tmp = __GTHREAD_MUTEX_INIT; | ||||
|       _M_mutex = __tmp; | ||||
| #else | ||||
|       __GTHREAD_MUTEX_INIT_FUNCTION(&_M_mutex); | ||||
|  | @ -103,22 +106,22 @@ namespace std | |||
|     native_handle_type | ||||
|     native_handle() | ||||
|     { return &_M_mutex; } | ||||
| 
 | ||||
|   private: | ||||
|     __gthread_mutex_t _M_mutex; | ||||
|   }; | ||||
| 
 | ||||
|   /// recursive_mutex | ||||
|   class recursive_mutex | ||||
|   { | ||||
|     typedef __gthread_recursive_mutex_t		__native_type; | ||||
|     __native_type  _M_mutex; | ||||
| 
 | ||||
|   public: | ||||
|     typedef __gthread_recursive_mutex_t* native_handle_type; | ||||
|     typedef __native_type* 			native_handle_type; | ||||
| 
 | ||||
|     recursive_mutex() | ||||
|     { | ||||
|       // XXX EAGAIN, ENOMEM, EPERM, EBUSY(may), EINVAL(may) | ||||
| #ifdef __GTHREAD_RECURSIVE_MUTEX_INIT | ||||
|       __gthread_recursive_mutex_t __tmp = __GTHREAD_RECURSIVE_MUTEX_INIT; | ||||
|       __native_type __tmp = __GTHREAD_RECURSIVE_MUTEX_INIT; | ||||
|       _M_mutex = __tmp; | ||||
| #else | ||||
|       __GTHREAD_RECURSIVE_MUTEX_INIT_FUNCTION(&_M_mutex); | ||||
|  | @ -155,21 +158,28 @@ namespace std | |||
|     native_handle_type | ||||
|     native_handle() | ||||
|     { return &_M_mutex; } | ||||
| 
 | ||||
|   private: | ||||
|     __gthread_recursive_mutex_t  _M_mutex; | ||||
|   }; | ||||
| 
 | ||||
|   /// timed_mutex | ||||
|   class timed_mutex | ||||
|   {   | ||||
|   { | ||||
|     typedef __gthread_mutex_t 		  	__native_type; | ||||
| 
 | ||||
| #ifdef _GLIBCXX_USE_CLOCK_MONOTONIC | ||||
|     typedef chrono::monotonic_clock 	  	__clock_t; | ||||
| #else | ||||
|     typedef chrono::high_resolution_clock 	__clock_t; | ||||
| #endif | ||||
| 
 | ||||
|     __native_type  _M_mutex; | ||||
| 
 | ||||
|   public: | ||||
|     typedef __gthread_mutex_t* native_handle_type; | ||||
|     typedef __native_type* 		  	native_handle_type; | ||||
| 
 | ||||
|     timed_mutex() | ||||
|     { | ||||
| #ifdef __GTHREAD_MUTEX_INIT | ||||
|       __gthread_mutex_t __tmp = __GTHREAD_MUTEX_INIT; | ||||
|       __native_type __tmp = __GTHREAD_MUTEX_INIT; | ||||
|       _M_mutex = __tmp; | ||||
| #else | ||||
|       __GTHREAD_MUTEX_INIT_FUNCTION(&_M_mutex); | ||||
|  | @ -204,19 +214,19 @@ namespace std | |||
|     template <class _Clock, class _Duration> | ||||
|       bool | ||||
|       try_lock_until(const chrono::time_point<_Clock, _Duration>& __atime) | ||||
|       {  | ||||
|       { | ||||
| 	chrono::time_point<_Clock, chrono::seconds> __s = | ||||
|           chrono::time_point_cast<chrono::seconds>(__atime); | ||||
| 	  chrono::time_point_cast<chrono::seconds>(__atime); | ||||
| 
 | ||||
| 	chrono::nanoseconds __ns = | ||||
|           chrono::duration_cast<chrono::nanoseconds>(__atime - __s); | ||||
| 	  chrono::duration_cast<chrono::nanoseconds>(__atime - __s); | ||||
| 
 | ||||
|         __gthread_time_t __ts = { | ||||
|           static_cast<std::time_t>(__s.time_since_epoch().count()), | ||||
|           static_cast<long>(__ns.count()) | ||||
|         }; | ||||
| 	__gthread_time_t __ts = { | ||||
| 	  static_cast<std::time_t>(__s.time_since_epoch().count()), | ||||
| 	  static_cast<long>(__ns.count()) | ||||
| 	}; | ||||
| 
 | ||||
| 	return !__gthread_mutex_timedlock(&_M_mutex, &__ts);	 | ||||
| 	return !__gthread_mutex_timedlock(&_M_mutex, &__ts); | ||||
|       } | ||||
| 
 | ||||
|     void | ||||
|  | @ -229,50 +239,52 @@ namespace std | |||
|     native_handle_type | ||||
|     native_handle() | ||||
|     { return &_M_mutex; } | ||||
|      | ||||
|   private: | ||||
|     __gthread_mutex_t _M_mutex; | ||||
|      | ||||
| #ifdef _GLIBCXX_USE_CLOCK_MONOTONIC | ||||
|     typedef chrono::monotonic_clock __clock_t; | ||||
| #else | ||||
|     typedef chrono::high_resolution_clock __clock_t; | ||||
| #endif | ||||
| 
 | ||||
|   private: | ||||
|     template<typename _Rep, typename _Period> | ||||
|       typename enable_if< | ||||
|         ratio_less_equal<__clock_t::period, _Period>::value, bool>::type | ||||
| 	ratio_less_equal<__clock_t::period, _Period>::value, bool>::type | ||||
|       __try_lock_for_impl(const chrono::duration<_Rep, _Period>& __rtime) | ||||
|       { | ||||
|         __clock_t::time_point __atime = __clock_t::now() | ||||
|           + chrono::duration_cast<__clock_t::duration>(__rtime); | ||||
| 	__clock_t::time_point __atime = __clock_t::now() | ||||
| 	  + chrono::duration_cast<__clock_t::duration>(__rtime); | ||||
| 
 | ||||
|         return try_lock_until(__atime); | ||||
| 	return try_lock_until(__atime); | ||||
|       } | ||||
| 
 | ||||
|     template <typename _Rep, typename _Period> | ||||
|       typename enable_if< | ||||
|         !ratio_less_equal<__clock_t::period, _Period>::value, bool>::type | ||||
| 	!ratio_less_equal<__clock_t::period, _Period>::value, bool>::type | ||||
|       __try_lock_for_impl(const chrono::duration<_Rep, _Period>& __rtime) | ||||
|       { | ||||
|         __clock_t::time_point __atime = __clock_t::now() | ||||
| 	__clock_t::time_point __atime = __clock_t::now() | ||||
| 	  + ++chrono::duration_cast<__clock_t::duration>(__rtime); | ||||
| 
 | ||||
|         return try_lock_until(__atime); | ||||
| 	return try_lock_until(__atime); | ||||
|       } | ||||
|   }; | ||||
| 
 | ||||
|   /// recursive_timed_mutex | ||||
|   class recursive_timed_mutex | ||||
|   { | ||||
|     typedef __gthread_recursive_mutex_t		__native_type; | ||||
| 
 | ||||
| #ifdef _GLIBCXX_USE_CLOCK_MONOTONIC | ||||
|     typedef chrono::monotonic_clock 		__clock_t; | ||||
| #else | ||||
|     typedef chrono::high_resolution_clock 	__clock_t; | ||||
| #endif | ||||
| 
 | ||||
|     __native_type  _M_mutex; | ||||
| 
 | ||||
|   public: | ||||
|     typedef __gthread_recursive_mutex_t* native_handle_type; | ||||
|     typedef __native_type* 			native_handle_type; | ||||
| 
 | ||||
|     recursive_timed_mutex() | ||||
|     { | ||||
|       // XXX EAGAIN, ENOMEM, EPERM, EBUSY(may), EINVAL(may) | ||||
| #ifdef __GTHREAD_RECURSIVE_MUTEX_INIT | ||||
|       __gthread_recursive_mutex_t __tmp = __GTHREAD_RECURSIVE_MUTEX_INIT; | ||||
|       __native_type __tmp = __GTHREAD_RECURSIVE_MUTEX_INIT; | ||||
|       _M_mutex = __tmp; | ||||
| #else | ||||
|       __GTHREAD_RECURSIVE_MUTEX_INIT_FUNCTION(&_M_mutex); | ||||
|  | @ -307,19 +319,19 @@ namespace std | |||
|     template <class _Clock, class _Duration> | ||||
|       bool | ||||
|       try_lock_until(const chrono::time_point<_Clock, _Duration>& __atime) | ||||
|       {  | ||||
|       { | ||||
| 	chrono::time_point<_Clock, chrono::seconds>  __s = | ||||
|           chrono::time_point_cast<chrono::seconds>(__atime); | ||||
| 	  chrono::time_point_cast<chrono::seconds>(__atime); | ||||
| 
 | ||||
| 	chrono::nanoseconds __ns = | ||||
|           chrono::duration_cast<chrono::nanoseconds>(__atime - __s); | ||||
| 	  chrono::duration_cast<chrono::nanoseconds>(__atime - __s); | ||||
| 
 | ||||
|         __gthread_time_t __ts = { | ||||
|           static_cast<std::time_t>(__s.time_since_epoch().count()), | ||||
|           static_cast<long>(__ns.count()) | ||||
|         }; | ||||
| 	__gthread_time_t __ts = { | ||||
| 	  static_cast<std::time_t>(__s.time_since_epoch().count()), | ||||
| 	  static_cast<long>(__ns.count()) | ||||
| 	}; | ||||
| 
 | ||||
|         return !__gthread_recursive_mutex_timedlock(&_M_mutex, &__ts); | ||||
| 	return !__gthread_recursive_mutex_timedlock(&_M_mutex, &__ts); | ||||
|       } | ||||
| 
 | ||||
|     void | ||||
|  | @ -334,34 +346,26 @@ namespace std | |||
|     { return &_M_mutex; } | ||||
| 
 | ||||
|   private: | ||||
|     __gthread_recursive_mutex_t _M_mutex; | ||||
| 
 | ||||
| #ifdef _GLIBCXX_USE_CLOCK_MONOTONIC | ||||
|     typedef chrono::monotonic_clock __clock_t; | ||||
| #else | ||||
|     typedef chrono::high_resolution_clock __clock_t; | ||||
| #endif | ||||
| 
 | ||||
|     template<typename _Rep, typename _Period> | ||||
|       typename enable_if< | ||||
|         ratio_less_equal<__clock_t::period, _Period>::value, bool>::type | ||||
| 	ratio_less_equal<__clock_t::period, _Period>::value, bool>::type | ||||
|       __try_lock_for_impl(const chrono::duration<_Rep, _Period>& __rtime) | ||||
|       { | ||||
|         __clock_t::time_point __atime = __clock_t::now() | ||||
|           + chrono::duration_cast<__clock_t::duration>(__rtime); | ||||
| 	__clock_t::time_point __atime = __clock_t::now() | ||||
| 	  + chrono::duration_cast<__clock_t::duration>(__rtime); | ||||
| 
 | ||||
|         return try_lock_until(__atime); | ||||
| 	return try_lock_until(__atime); | ||||
|       } | ||||
| 
 | ||||
|     template <typename _Rep, typename _Period> | ||||
|       typename enable_if< | ||||
|         !ratio_less_equal<__clock_t::period, _Period>::value, bool>::type | ||||
| 	!ratio_less_equal<__clock_t::period, _Period>::value, bool>::type | ||||
|       __try_lock_for_impl(const chrono::duration<_Rep, _Period>& __rtime) | ||||
|       { | ||||
|         __clock_t::time_point __atime = __clock_t::now() | ||||
| 	__clock_t::time_point __atime = __clock_t::now() | ||||
| 	  + ++chrono::duration_cast<__clock_t::duration>(__rtime); | ||||
| 
 | ||||
|         return try_lock_until(__atime); | ||||
| 	return try_lock_until(__atime); | ||||
|       } | ||||
|   }; | ||||
| 
 | ||||
|  | @ -418,7 +422,7 @@ namespace std | |||
|     { | ||||
|     public: | ||||
|       typedef _Mutex mutex_type; | ||||
|        | ||||
| 
 | ||||
|       unique_lock() | ||||
|       : _M_device(0), _M_owns(false) | ||||
|       { } | ||||
|  | @ -445,13 +449,13 @@ namespace std | |||
|       } | ||||
| 
 | ||||
|       template<typename _Clock, typename _Duration> | ||||
| 	unique_lock(mutex_type& __m,  | ||||
| 	unique_lock(mutex_type& __m, | ||||
| 		    const chrono::time_point<_Clock, _Duration>& __atime) | ||||
| 	: _M_device(&__m), _M_owns(_M_device->try_lock_until(__atime)) | ||||
| 	{ } | ||||
| 
 | ||||
|       template<typename _Rep, typename _Period> | ||||
| 	unique_lock(mutex_type& __m,  | ||||
| 	unique_lock(mutex_type& __m, | ||||
| 		    const chrono::duration<_Rep, _Period>& __rtime) | ||||
| 	: _M_device(&__m), _M_owns(_M_device->try_lock_for(__rtime)) | ||||
| 	{ } | ||||
|  | @ -474,14 +478,14 @@ namespace std | |||
| 
 | ||||
|       unique_lock& operator=(unique_lock&& __u) | ||||
|       { | ||||
|         if(_M_owns) | ||||
| 	if(_M_owns) | ||||
| 	  unlock(); | ||||
| 	 | ||||
| 
 | ||||
| 	unique_lock(std::move(__u)).swap(*this); | ||||
| 
 | ||||
| 	__u._M_device = 0; | ||||
| 	__u._M_owns = false; | ||||
| 	 | ||||
| 
 | ||||
| 	return *this; | ||||
|       } | ||||
| 
 | ||||
|  | @ -503,20 +507,20 @@ namespace std | |||
|       try_lock() | ||||
|       { | ||||
| 	if (!_M_device) | ||||
|           __throw_system_error((int)errc::operation_not_permitted); | ||||
|         else if (_M_owns) | ||||
|           __throw_system_error((int)errc::resource_deadlock_would_occur); | ||||
|         else | ||||
| 	  __throw_system_error((int)errc::operation_not_permitted); | ||||
| 	else if (_M_owns) | ||||
| 	  __throw_system_error((int)errc::resource_deadlock_would_occur); | ||||
| 	else | ||||
| 	  { | ||||
| 	    _M_owns = _M_device->try_lock();	     | ||||
| 	    _M_owns = _M_device->try_lock(); | ||||
| 	    return _M_owns; | ||||
| 	  } | ||||
|       } | ||||
| 
 | ||||
|       template<typename _Clock, typename _Duration> | ||||
|         bool | ||||
|         try_lock_until(const chrono::time_point<_Clock, _Duration>& __atime) | ||||
|         { | ||||
| 	bool | ||||
| 	try_lock_until(const chrono::time_point<_Clock, _Duration>& __atime) | ||||
| 	{ | ||||
| 	  if (!_M_device) | ||||
| 	    __throw_system_error((int)errc::operation_not_permitted); | ||||
| 	  else if (_M_owns) | ||||
|  | @ -527,11 +531,11 @@ namespace std | |||
| 	      return _M_owns; | ||||
| 	    } | ||||
| 	} | ||||
|        | ||||
| 
 | ||||
|       template<typename _Rep, typename _Period> | ||||
| 	bool | ||||
| 	try_lock_for(const chrono::duration<_Rep, _Period>& __rtime) | ||||
|         { | ||||
| 	{ | ||||
| 	  if (!_M_device) | ||||
| 	    __throw_system_error((int)errc::operation_not_permitted); | ||||
| 	  else if (_M_owns) | ||||
|  | @ -546,15 +550,15 @@ namespace std | |||
|       void | ||||
|       unlock() | ||||
|       { | ||||
|         if (!_M_owns) | ||||
|           __throw_system_error((int)errc::operation_not_permitted); | ||||
|         else if (_M_device) | ||||
|           { | ||||
|             _M_device->unlock(); | ||||
|             _M_owns = false; | ||||
|           } | ||||
| 	if (!_M_owns) | ||||
| 	  __throw_system_error((int)errc::operation_not_permitted); | ||||
| 	else if (_M_device) | ||||
| 	  { | ||||
| 	    _M_device->unlock(); | ||||
| 	    _M_owns = false; | ||||
| 	  } | ||||
|       } | ||||
|        | ||||
| 
 | ||||
|       void | ||||
|       swap(unique_lock&& __u) | ||||
|       { | ||||
|  | @ -606,30 +610,30 @@ namespace std | |||
|     struct __unlock_impl | ||||
|     { | ||||
|       template<typename... _Lock> | ||||
|         static void | ||||
|         __do_unlock(tuple<_Lock&...>& __locks) | ||||
|         { | ||||
| 	static void | ||||
| 	__do_unlock(tuple<_Lock&...>& __locks) | ||||
| 	{ | ||||
| 	  std::get<_Idx>(__locks).unlock(); | ||||
| 	  __unlock_impl<_Idx - 1>::__do_unlock(__locks); | ||||
| 	} | ||||
|     }; | ||||
|    | ||||
| 
 | ||||
|   template<> | ||||
|     struct __unlock_impl<-1> | ||||
|     { | ||||
|       template<typename... _Lock> | ||||
|         static void | ||||
|         __do_unlock(tuple<_Lock&...>&) | ||||
|         { } | ||||
| 	static void | ||||
| 	__do_unlock(tuple<_Lock&...>&) | ||||
| 	{ } | ||||
|     }; | ||||
| 
 | ||||
|   template<int _Idx, bool _Continue = true> | ||||
|     struct __try_lock_impl | ||||
|     { | ||||
|       template<typename... _Lock> | ||||
|         static int | ||||
|         __do_try_lock(tuple<_Lock&...>& __locks) | ||||
|         { | ||||
| 	static int | ||||
| 	__do_try_lock(tuple<_Lock&...>& __locks) | ||||
| 	{ | ||||
| 	  if(std::get<_Idx>(__locks).try_lock()) | ||||
| 	    { | ||||
| 	      return __try_lock_impl<_Idx + 1, | ||||
|  | @ -642,14 +646,14 @@ namespace std | |||
| 	    } | ||||
| 	} | ||||
|     }; | ||||
|    | ||||
| 
 | ||||
|   template<int _Idx> | ||||
|     struct __try_lock_impl<_Idx, false> | ||||
|     { | ||||
|       template<typename... _Lock> | ||||
|         static int | ||||
|         __do_try_lock(tuple<_Lock&...>& __locks) | ||||
|         { | ||||
| 	static int | ||||
| 	__do_try_lock(tuple<_Lock&...>& __locks) | ||||
| 	{ | ||||
| 	  if(std::get<_Idx>(__locks).try_lock()) | ||||
| 	    return -1; | ||||
| 	  else | ||||
|  | @ -659,12 +663,12 @@ namespace std | |||
| 	    } | ||||
| 	} | ||||
|     }; | ||||
|    | ||||
| 
 | ||||
|   /** @brief Generic try_lock. | ||||
|    *  @param __l1 Meets Mutex requirements (try_lock() may throw). | ||||
|    *  @param __l2 Meets Mutex requirements (try_lock() may throw). | ||||
|    *  @param __l3 Meets Mutex requirements (try_lock() may throw). | ||||
|    *  @return Returns -1 if all try_lock() calls return true. Otherwise returns  | ||||
|    *  @return Returns -1 if all try_lock() calls return true. Otherwise returns | ||||
|    *          a 0-based index corresponding to the argument that returned false. | ||||
|    *  @post Either all arguments are locked, or none will be. | ||||
|    * | ||||
|  | @ -685,23 +689,23 @@ namespace std | |||
|   /// once_flag | ||||
|   struct once_flag | ||||
|   { | ||||
|   private: | ||||
|     typedef __gthread_once_t __native_type; | ||||
|     __native_type  _M_once; | ||||
| 
 | ||||
|   public: | ||||
|     once_flag() | ||||
|     { | ||||
|       __gthread_once_t __tmp = __GTHREAD_ONCE_INIT; | ||||
|       __native_type __tmp = __GTHREAD_ONCE_INIT; | ||||
|       _M_once = __tmp; | ||||
|     } | ||||
|      | ||||
| 
 | ||||
|     once_flag(const once_flag&) = delete; | ||||
|     once_flag& operator=(const once_flag&) = delete; | ||||
| 
 | ||||
|     template<typename _Callable, typename... _Args> | ||||
|       friend void | ||||
|       call_once(once_flag& __once, _Callable __f, _Args&&... __args); | ||||
| 
 | ||||
|   private: | ||||
|     __native_type  _M_once; | ||||
|   }; | ||||
| 
 | ||||
| #ifdef _GLIBCXX_HAVE_TLS | ||||
|  | @ -709,7 +713,7 @@ namespace std | |||
|   extern __thread void (*__once_call)(); | ||||
| 
 | ||||
|   template<typename _Callable> | ||||
|     inline void  | ||||
|     inline void | ||||
|     __once_call_impl() | ||||
|     { | ||||
|       (*(_Callable*)__once_callable)(); | ||||
|  | @ -736,10 +740,10 @@ namespace std | |||
|       __functor_lock.lock(); | ||||
|       __once_functor = bind(__f, __args...); | ||||
| #endif | ||||
|       | ||||
| 
 | ||||
|       int __e = __gthread_once(&(__once._M_once), &__once_proxy); | ||||
| 
 | ||||
| #ifndef _GLIBCXX_HAVE_TLS       | ||||
| #ifndef _GLIBCXX_HAVE_TLS | ||||
|       if (__functor_lock) | ||||
| 	__functor_lock.unlock(); | ||||
| #endif | ||||
|  |  | |||
|  | @ -57,7 +57,9 @@ namespace std | |||
|   class thread | ||||
|   { | ||||
|   public: | ||||
|     typedef __gthread_t 	 	native_handle_type; | ||||
|     typedef __gthread_t	 		native_handle_type; | ||||
|     struct _Impl_base; | ||||
|     typedef shared_ptr<_Impl_base>	__shared_base_type; | ||||
| 
 | ||||
|     /// thread::id | ||||
|     class id | ||||
|  | @ -86,9 +88,6 @@ namespace std | |||
| 	operator<<(basic_ostream<_CharT, _Traits>&& __out, thread::id __id); | ||||
|     }; | ||||
| 
 | ||||
|     struct _Impl_base; | ||||
|     typedef shared_ptr<_Impl_base>	__shared_base_type; | ||||
| 
 | ||||
|     struct _Impl_base | ||||
|     { | ||||
|       id			_M_id; | ||||
|  | @ -239,21 +238,25 @@ namespace std | |||
|   // 30.2.2 Namespace this_thread. | ||||
|   namespace this_thread | ||||
|   { | ||||
|     /// get_id | ||||
|     inline thread::id | ||||
|     get_id() { return thread::id(__gthread_self()); } | ||||
| 
 | ||||
| #ifdef _GLIBCXX_USE_SCHED_YIELD | ||||
|     /// yield | ||||
|     inline void | ||||
|     yield() | ||||
|     { __gthread_yield(); } | ||||
| #endif | ||||
| 
 | ||||
| #ifdef _GLIBCXX_USE_NANOSLEEP | ||||
|     /// sleep_until | ||||
|     template<typename _Clock, typename _Duration> | ||||
|       inline void | ||||
|       sleep_until(const chrono::time_point<_Clock, _Duration>& __atime) | ||||
|       { sleep_for(__atime - _Clock::now()); } | ||||
| 
 | ||||
|     /// sleep_for | ||||
|     template<typename _Rep, typename _Period> | ||||
|       inline void | ||||
|       sleep_for(const chrono::duration<_Rep, _Period>& __rtime) | ||||
|  |  | |||
|  | @ -1,6 +1,6 @@ | |||
| // condition_variable -*- C++ -*-
 | ||||
| 
 | ||||
| // Copyright (C) 2008 Free Software Foundation, Inc.
 | ||||
| // Copyright (C) 2008, 2009 Free Software Foundation, Inc.
 | ||||
| //
 | ||||
| // This file is part of the GNU ISO C++ Library.  This library is free
 | ||||
| // software; you can redistribute it and/or modify it under the
 | ||||
|  | @ -36,7 +36,7 @@ namespace std | |||
|   condition_variable::condition_variable() | ||||
|   { | ||||
| #ifdef __GTHREAD_COND_INIT | ||||
|     __gthread_cond_t __tmp = __GTHREAD_COND_INIT; | ||||
|     __native_type __tmp = __GTHREAD_COND_INIT; | ||||
|     _M_cond = __tmp; | ||||
| #else | ||||
|     int __e = __gthread_cond_init(&_M_cond, NULL); | ||||
|  | @ -65,7 +65,6 @@ namespace std | |||
|   void  | ||||
|   condition_variable::notify_one() | ||||
|   {  | ||||
|     lock_guard<mutex> __lock(_M_internal_mutex); | ||||
|     int __e = __gthread_cond_signal(&_M_cond); | ||||
| 
 | ||||
|     // XXX not in spec
 | ||||
|  | @ -77,7 +76,6 @@ namespace std | |||
|   void  | ||||
|   condition_variable::notify_all() | ||||
|   {  | ||||
|     lock_guard<mutex> __lock(_M_internal_mutex); | ||||
|     int __e = __gthread_cond_broadcast(&_M_cond); | ||||
| 
 | ||||
|     // XXX not in spec
 | ||||
|  | @ -89,7 +87,7 @@ namespace std | |||
|   condition_variable_any::condition_variable_any() | ||||
|   { | ||||
| #ifdef __GTHREAD_COND_INIT | ||||
|     __gthread_cond_t __tmp = __GTHREAD_COND_INIT; | ||||
|     __native_type __tmp = __GTHREAD_COND_INIT; | ||||
|     _M_cond = __tmp; | ||||
| #else | ||||
|     int __e = __gthread_cond_init(&_M_cond, NULL); | ||||
|  |  | |||
|  | @ -45,7 +45,7 @@ namespace std | |||
| 
 | ||||
|       __try | ||||
| 	{ | ||||
| 	  __local->_M_run(); | ||||
| 	  __t->_M_run(); | ||||
| 	} | ||||
|       __catch(...) | ||||
| 	{ | ||||
|  | @ -90,7 +90,6 @@ namespace std | |||
|   void | ||||
|   thread::_M_start_thread() | ||||
|   { | ||||
|     // _M_data->_M_this_ptr = _M_data;
 | ||||
|     _M_data->_M_this_ptr = _M_data; | ||||
|     int __e = __gthread_create(&_M_data->_M_id._M_thread, | ||||
| 			       &execute_native_thread_routine, _M_data.get()); | ||||
|  |  | |||
|  | @ -3,7 +3,7 @@ | |||
| // { dg-require-cstdint "" }
 | ||||
| // { dg-require-gthreads "" }
 | ||||
| 
 | ||||
| // Copyright (C) 2008 Free Software Foundation, Inc.
 | ||||
| // Copyright (C) 2008, 2009 Free Software Foundation, Inc.
 | ||||
| //
 | ||||
| // This file is part of the GNU ISO C++ Library.  This library is free
 | ||||
| // software; you can redistribute it and/or modify it under the
 | ||||
|  | @ -41,4 +41,4 @@ void test01() | |||
| } | ||||
| 
 | ||||
| // { dg-error "used here" "" { target *-*-* } 40 }
 | ||||
| // { dg-error "deleted function" "" { target *-*-* } 62 }
 | ||||
| // { dg-error "deleted function" "" { target *-*-* } 64 }
 | ||||
|  |  | |||
|  | @ -3,7 +3,7 @@ | |||
| // { dg-require-cstdint "" }
 | ||||
| // { dg-require-gthreads "" }
 | ||||
| 
 | ||||
| // Copyright (C) 2008 Free Software Foundation, Inc.
 | ||||
| // Copyright (C) 2008, 2009 Free Software Foundation, Inc.
 | ||||
| //
 | ||||
| // This file is part of the GNU ISO C++ Library.  This library is free
 | ||||
| // software; you can redistribute it and/or modify it under the
 | ||||
|  | @ -40,4 +40,4 @@ void test01() | |||
| } | ||||
| 
 | ||||
| // { dg-error "used here" "" { target *-*-* } 39 }
 | ||||
| // { dg-error "deleted function" "" { target *-*-* } 61 }
 | ||||
| // { dg-error "deleted function" "" { target *-*-* } 63 }
 | ||||
|  |  | |||
|  | @ -0,0 +1,34 @@ | |||
| // { dg-do run { target *-*-freebsd* *-*-netbsd* *-*-linux* *-*-solaris* *-*-cygwin *-*-darwin* alpha*-*-osf* mips-sgi-irix6* } }
 | ||||
| // { dg-options " -std=gnu++0x -pthread" { target *-*-freebsd* *-*-netbsd* *-*-linux* alpha*-*-osf* mips-sgi-irix6* } }
 | ||||
| // { dg-options " -std=gnu++0x -pthreads" { target *-*-solaris* } }
 | ||||
| // { dg-options " -std=gnu++0x " { target *-*-cygwin *-*-darwin* } }
 | ||||
| // { dg-require-cstdint "" }
 | ||||
| // { dg-require-gthreads "" }
 | ||||
| 
 | ||||
| // Copyright (C) 2009 Free Software Foundation, Inc.
 | ||||
| //
 | ||||
| // This file is part of the GNU ISO C++ Library.  This library is free
 | ||||
| // software; you can redistribute it and/or modify it under the
 | ||||
| // terms of the GNU General Public License as published by the
 | ||||
| // Free Software Foundation; either version 2, or (at your option)
 | ||||
| // any later version.
 | ||||
| 
 | ||||
| // This library is distributed in the hope that it will be useful,
 | ||||
| // but WITHOUT ANY WARRANTY; without even the implied warranty of
 | ||||
| // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | ||||
| // GNU General Public License for more details.
 | ||||
| 
 | ||||
| // You should have received a copy of the GNU General Public License along
 | ||||
| // with this library; see the file COPYING.  If not, write to the Free
 | ||||
| // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
 | ||||
| // USA.
 | ||||
| 
 | ||||
| #include <thread/all.h> | ||||
| #include <condition_variable> | ||||
| 
 | ||||
| int main() | ||||
| { | ||||
|   typedef std::condition_variable test_type; | ||||
|   __gnu_test::compare_type_to_native_type_sizes<test_type>(); | ||||
|   return 0; | ||||
| } | ||||
|  | @ -3,7 +3,7 @@ | |||
| // { dg-require-cstdint "" }
 | ||||
| // { dg-require-gthreads "" }
 | ||||
| 
 | ||||
| // Copyright (C) 2008 Free Software Foundation, Inc.
 | ||||
| // Copyright (C) 2008, 2009 Free Software Foundation, Inc.
 | ||||
| //
 | ||||
| // This file is part of the GNU ISO C++ Library.  This library is free
 | ||||
| // software; you can redistribute it and/or modify it under the
 | ||||
|  | @ -41,4 +41,4 @@ void test01() | |||
| } | ||||
| 
 | ||||
| // { dg-error "used here" "" { target *-*-* } 40 }
 | ||||
| // { dg-error "deleted function" "" { target *-*-* } 170 }
 | ||||
| // { dg-error "deleted function" "" { target *-*-* } 172 }
 | ||||
|  |  | |||
|  | @ -3,7 +3,7 @@ | |||
| // { dg-require-cstdint "" }
 | ||||
| // { dg-require-gthreads "" }
 | ||||
| 
 | ||||
| // Copyright (C) 2008 Free Software Foundation, Inc.
 | ||||
| // Copyright (C) 2008, 2009 Free Software Foundation, Inc.
 | ||||
| //
 | ||||
| // This file is part of the GNU ISO C++ Library.  This library is free
 | ||||
| // software; you can redistribute it and/or modify it under the
 | ||||
|  | @ -40,4 +40,4 @@ void test01() | |||
| } | ||||
| 
 | ||||
| // { dg-error "used here" "" { target *-*-* } 39 }
 | ||||
| // { dg-error "deleted function" "" { target *-*-* } 169 }
 | ||||
| // { dg-error "deleted function" "" { target *-*-* } 171 }
 | ||||
|  |  | |||
|  | @ -0,0 +1,34 @@ | |||
| // { dg-do run { target *-*-freebsd* *-*-netbsd* *-*-linux* *-*-solaris* *-*-cygwin *-*-darwin* alpha*-*-osf* mips-sgi-irix6* } }
 | ||||
| // { dg-options " -std=gnu++0x -pthread" { target *-*-freebsd* *-*-netbsd* *-*-linux* alpha*-*-osf* mips-sgi-irix6* } }
 | ||||
| // { dg-options " -std=gnu++0x -pthreads" { target *-*-solaris* } }
 | ||||
| // { dg-options " -std=gnu++0x " { target *-*-cygwin *-*-darwin* } }
 | ||||
| // { dg-require-cstdint "" }
 | ||||
| // { dg-require-gthreads "" }
 | ||||
| 
 | ||||
| // Copyright (C) 2009 Free Software Foundation, Inc.
 | ||||
| //
 | ||||
| // This file is part of the GNU ISO C++ Library.  This library is free
 | ||||
| // software; you can redistribute it and/or modify it under the
 | ||||
| // terms of the GNU General Public License as published by the
 | ||||
| // Free Software Foundation; either version 2, or (at your option)
 | ||||
| // any later version.
 | ||||
| 
 | ||||
| // This library is distributed in the hope that it will be useful,
 | ||||
| // but WITHOUT ANY WARRANTY; without even the implied warranty of
 | ||||
| // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | ||||
| // GNU General Public License for more details.
 | ||||
| 
 | ||||
| // You should have received a copy of the GNU General Public License along
 | ||||
| // with this library; see the file COPYING.  If not, write to the Free
 | ||||
| // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
 | ||||
| // USA.
 | ||||
| 
 | ||||
| #include <thread/all.h> | ||||
| #include <condition_variable> | ||||
| 
 | ||||
| int main() | ||||
| { | ||||
|   typedef std::condition_variable_any test_type; | ||||
|   __gnu_test::compare_type_to_native_type_sizes<test_type>(); | ||||
|   return 0; | ||||
| } | ||||
|  | @ -3,7 +3,7 @@ | |||
| // { dg-require-cstdint "" }
 | ||||
| // { dg-require-gthreads "" }
 | ||||
| 
 | ||||
| // Copyright (C) 2008 Free Software Foundation, Inc.
 | ||||
| // Copyright (C) 2008, 2009 Free Software Foundation, Inc.
 | ||||
| //
 | ||||
| // This file is part of the GNU ISO C++ Library.  This library is free
 | ||||
| // software; you can redistribute it and/or modify it under the
 | ||||
|  | @ -42,4 +42,4 @@ void test01() | |||
| } | ||||
| 
 | ||||
| // { dg-error "used here" "" { target *-*-* } 41 }
 | ||||
| // { dg-error "deleted function" "" { target *-*-* } 77 }
 | ||||
| // { dg-error "deleted function" "" { target *-*-* } 80 }
 | ||||
|  |  | |||
|  | @ -3,7 +3,7 @@ | |||
| // { dg-require-cstdint "" }
 | ||||
| // { dg-require-gthreads "" }
 | ||||
| 
 | ||||
| // Copyright (C) 2008 Free Software Foundation, Inc.
 | ||||
| // Copyright (C) 2008, 2009 Free Software Foundation, Inc.
 | ||||
| //
 | ||||
| // This file is part of the GNU ISO C++ Library.  This library is free
 | ||||
| // software; you can redistribute it and/or modify it under the
 | ||||
|  | @ -41,4 +41,4 @@ void test01() | |||
| } | ||||
| 
 | ||||
| // { dg-error "used here" "" { target *-*-* } 40 }
 | ||||
| // { dg-error "deleted function" "" { target *-*-* } 76 }
 | ||||
| // { dg-error "deleted function" "" { target *-*-* } 79 }
 | ||||
|  |  | |||
|  | @ -0,0 +1,34 @@ | |||
| // { dg-do run { target *-*-freebsd* *-*-netbsd* *-*-linux* *-*-solaris* *-*-cygwin *-*-darwin* alpha*-*-osf* mips-sgi-irix6* } }
 | ||||
| // { dg-options " -std=gnu++0x -pthread" { target *-*-freebsd* *-*-netbsd* *-*-linux* alpha*-*-osf* mips-sgi-irix6* } }
 | ||||
| // { dg-options " -std=gnu++0x -pthreads" { target *-*-solaris* } }
 | ||||
| // { dg-options " -std=gnu++0x " { target *-*-cygwin *-*-darwin* } }
 | ||||
| // { dg-require-cstdint "" }
 | ||||
| // { dg-require-gthreads "" }
 | ||||
| 
 | ||||
| // Copyright (C) 2009 Free Software Foundation, Inc.
 | ||||
| //
 | ||||
| // This file is part of the GNU ISO C++ Library.  This library is free
 | ||||
| // software; you can redistribute it and/or modify it under the
 | ||||
| // terms of the GNU General Public License as published by the
 | ||||
| // Free Software Foundation; either version 2, or (at your option)
 | ||||
| // any later version.
 | ||||
| 
 | ||||
| // This library is distributed in the hope that it will be useful,
 | ||||
| // but WITHOUT ANY WARRANTY; without even the implied warranty of
 | ||||
| // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | ||||
| // GNU General Public License for more details.
 | ||||
| 
 | ||||
| // You should have received a copy of the GNU General Public License along
 | ||||
| // with this library; see the file COPYING.  If not, write to the Free
 | ||||
| // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
 | ||||
| // USA.
 | ||||
| 
 | ||||
| #include <thread/all.h> | ||||
| #include <mutex> | ||||
| 
 | ||||
| int main() | ||||
| { | ||||
|   typedef std::mutex test_type; | ||||
|   __gnu_test::compare_type_to_native_type_sizes<test_type>(); | ||||
|   return 0; | ||||
| } | ||||
|  | @ -3,7 +3,7 @@ | |||
| // { dg-require-cstdint "" }
 | ||||
| // { dg-require-gthreads "" }
 | ||||
| 
 | ||||
| // Copyright (C) 2008 Free Software Foundation, Inc.
 | ||||
| // Copyright (C) 2008, 2009 Free Software Foundation, Inc.
 | ||||
| //
 | ||||
| // This file is part of the GNU ISO C++ Library.  This library is free
 | ||||
| // software; you can redistribute it and/or modify it under the
 | ||||
|  | @ -42,4 +42,4 @@ void test01() | |||
| } | ||||
| 
 | ||||
| // { dg-error "used here" "" { target *-*-* } 41 } 
 | ||||
| // { dg-error "deleted function" "" { target *-*-* } 129 }
 | ||||
| // { dg-error "deleted function" "" { target *-*-* } 132 }
 | ||||
|  |  | |||
|  | @ -3,7 +3,7 @@ | |||
| // { dg-require-cstdint "" }
 | ||||
| // { dg-require-gthreads "" }
 | ||||
| 
 | ||||
| // Copyright (C) 2008 Free Software Foundation, Inc.
 | ||||
| // Copyright (C) 2008, 2009 Free Software Foundation, Inc.
 | ||||
| //
 | ||||
| // This file is part of the GNU ISO C++ Library.  This library is free
 | ||||
| // software; you can redistribute it and/or modify it under the
 | ||||
|  | @ -41,4 +41,4 @@ void test01() | |||
| } | ||||
| 
 | ||||
| // { dg-error "used here" "" { target *-*-* } 40 } 
 | ||||
| // { dg-error "deleted function" "" { target *-*-* } 128 }
 | ||||
| // { dg-error "deleted function" "" { target *-*-* } 131 }
 | ||||
|  |  | |||
|  | @ -0,0 +1,34 @@ | |||
| // { dg-do run { target *-*-freebsd* *-*-netbsd* *-*-linux* *-*-solaris* *-*-cygwin *-*-darwin* alpha*-*-osf* mips-sgi-irix6* } }
 | ||||
| // { dg-options " -std=gnu++0x -pthread" { target *-*-freebsd* *-*-netbsd* *-*-linux* alpha*-*-osf* mips-sgi-irix6* } }
 | ||||
| // { dg-options " -std=gnu++0x -pthreads" { target *-*-solaris* } }
 | ||||
| // { dg-options " -std=gnu++0x " { target *-*-cygwin *-*-darwin* } }
 | ||||
| // { dg-require-cstdint "" }
 | ||||
| // { dg-require-gthreads "" }
 | ||||
| 
 | ||||
| // Copyright (C) 2009 Free Software Foundation, Inc.
 | ||||
| //
 | ||||
| // This file is part of the GNU ISO C++ Library.  This library is free
 | ||||
| // software; you can redistribute it and/or modify it under the
 | ||||
| // terms of the GNU General Public License as published by the
 | ||||
| // Free Software Foundation; either version 2, or (at your option)
 | ||||
| // any later version.
 | ||||
| 
 | ||||
| // This library is distributed in the hope that it will be useful,
 | ||||
| // but WITHOUT ANY WARRANTY; without even the implied warranty of
 | ||||
| // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | ||||
| // GNU General Public License for more details.
 | ||||
| 
 | ||||
| // You should have received a copy of the GNU General Public License along
 | ||||
| // with this library; see the file COPYING.  If not, write to the Free
 | ||||
| // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
 | ||||
| // USA.
 | ||||
| 
 | ||||
| #include <thread/all.h> | ||||
| #include <mutex> | ||||
| 
 | ||||
| int main() | ||||
| { | ||||
|   typedef std::recursive_mutex test_type; | ||||
|   __gnu_test::compare_type_to_native_type_sizes<test_type>(); | ||||
|   return 0; | ||||
| } | ||||
|  | @ -42,4 +42,4 @@ void test01() | |||
| } | ||||
| 
 | ||||
| // { dg-error "used here" "" { target *-*-* } 41 } 
 | ||||
| // { dg-error "deleted function" "" { target *-*-* } 283 }
 | ||||
| // { dg-error "deleted function" "" { target *-*-* } 295 }
 | ||||
|  |  | |||
|  | @ -41,4 +41,4 @@ void test01() | |||
| } | ||||
| 
 | ||||
| // { dg-error "used here" "" { target *-*-* } 40 } 
 | ||||
| // { dg-error "deleted function" "" { target *-*-* } 282 }
 | ||||
| // { dg-error "deleted function" "" { target *-*-* } 294 }
 | ||||
|  |  | |||
|  | @ -0,0 +1,34 @@ | |||
| // { dg-do run { target *-*-freebsd* *-*-netbsd* *-*-linux* *-*-solaris* *-*-cygwin *-*-darwin* alpha*-*-osf* mips-sgi-irix6* } }
 | ||||
| // { dg-options " -std=gnu++0x -pthread" { target *-*-freebsd* *-*-netbsd* *-*-linux* alpha*-*-osf* mips-sgi-irix6* } }
 | ||||
| // { dg-options " -std=gnu++0x -pthreads" { target *-*-solaris* } }
 | ||||
| // { dg-options " -std=gnu++0x " { target *-*-cygwin *-*-darwin* } }
 | ||||
| // { dg-require-cstdint "" }
 | ||||
| // { dg-require-gthreads "" }
 | ||||
| 
 | ||||
| // Copyright (C) 2009 Free Software Foundation, Inc.
 | ||||
| //
 | ||||
| // This file is part of the GNU ISO C++ Library.  This library is free
 | ||||
| // software; you can redistribute it and/or modify it under the
 | ||||
| // terms of the GNU General Public License as published by the
 | ||||
| // Free Software Foundation; either version 2, or (at your option)
 | ||||
| // any later version.
 | ||||
| 
 | ||||
| // This library is distributed in the hope that it will be useful,
 | ||||
| // but WITHOUT ANY WARRANTY; without even the implied warranty of
 | ||||
| // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | ||||
| // GNU General Public License for more details.
 | ||||
| 
 | ||||
| // You should have received a copy of the GNU General Public License along
 | ||||
| // with this library; see the file COPYING.  If not, write to the Free
 | ||||
| // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
 | ||||
| // USA.
 | ||||
| 
 | ||||
| #include <mutex> | ||||
| #include <thread/all.h> | ||||
| 
 | ||||
| int main() | ||||
| { | ||||
|   typedef std::recursive_timed_mutex test_type; | ||||
|   __gnu_test::compare_type_to_native_type_sizes<test_type>(); | ||||
|   return 0; | ||||
| } | ||||
|  | @ -33,4 +33,4 @@ void test01() | |||
| } | ||||
| 
 | ||||
| // { dg-error "used here" "" { target *-*-* } 32 }
 | ||||
| // { dg-error "deleted function" "" { target *-*-* } 145 }
 | ||||
| // { dg-error "deleted function" "" { target *-*-* } 144 }
 | ||||
|  |  | |||
|  | @ -28,9 +28,9 @@ void test01() | |||
|   // copy
 | ||||
|   typedef std::thread test_type; | ||||
|   test_type t1; | ||||
|   test_type t2(t1); | ||||
|   test_type t2(t1); // XXX this is failing for the wrong reason
 | ||||
| } | ||||
| 
 | ||||
| // { dg-error "here" "" { target *-*-* } 31 }
 | ||||
| // { dg-error "deleted function" "" { target *-*-* } 124 }
 | ||||
| // { dg-error "deleted function" "" { target *-*-* } 123 }
 | ||||
| // { dg-excess-errors "In file included from" }
 | ||||
|  |  | |||
|  | @ -0,0 +1,35 @@ | |||
| // { dg-do run { target *-*-freebsd* *-*-netbsd* *-*-linux* *-*-solaris* *-*-cygwin *-*-darwin* alpha*-*-osf* mips-sgi-irix6* } }
 | ||||
| // { dg-options " -std=gnu++0x -pthread" { target *-*-freebsd* *-*-netbsd* *-*-linux* alpha*-*-osf* mips-sgi-irix6* } }
 | ||||
| // { dg-options " -std=gnu++0x -pthreads" { target *-*-solaris* } }
 | ||||
| // { dg-options " -std=gnu++0x " { target *-*-cygwin *-*-darwin* } }
 | ||||
| // { dg-require-cstdint "" }
 | ||||
| // { dg-require-gthreads "" }
 | ||||
| 
 | ||||
| // Copyright (C) 2009 Free Software Foundation, Inc.
 | ||||
| //
 | ||||
| // This file is part of the GNU ISO C++ Library.  This library is free
 | ||||
| // software; you can redistribute it and/or modify it under the
 | ||||
| // terms of the GNU General Public License as published by the
 | ||||
| // Free Software Foundation; either version 2, or (at your option)
 | ||||
| // any later version.
 | ||||
| 
 | ||||
| // This library is distributed in the hope that it will be useful,
 | ||||
| // but WITHOUT ANY WARRANTY; without even the implied warranty of
 | ||||
| // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | ||||
| // GNU General Public License for more details.
 | ||||
| 
 | ||||
| // You should have received a copy of the GNU General Public License along
 | ||||
| // with this library; see the file COPYING.  If not, write to the Free
 | ||||
| // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
 | ||||
| // USA.
 | ||||
| 
 | ||||
| #include <thread/all.h> | ||||
| #include <thread> | ||||
| 
 | ||||
| int main() | ||||
| { | ||||
|   typedef std::thread test_type; | ||||
|   // XXX disable at the moment
 | ||||
|   //__gnu_test::compare_type_to_native_type_sizes<test_type>();
 | ||||
|   return 0; | ||||
| } | ||||
|  | @ -3,7 +3,7 @@ | |||
| // { dg-require-cstdint "" }
 | ||||
| // { dg-require-gthreads "" }
 | ||||
| 
 | ||||
| // Copyright (C) 2008 Free Software Foundation, Inc.
 | ||||
| // Copyright (C) 2008, 2009 Free Software Foundation, Inc.
 | ||||
| //
 | ||||
| // This file is part of the GNU ISO C++ Library.  This library is free
 | ||||
| // software; you can redistribute it and/or modify it under the
 | ||||
|  | @ -42,4 +42,4 @@ void test01() | |||
| } | ||||
| 
 | ||||
| // { dg-error "used here" "" { target *-*-* } 41 } 
 | ||||
| // { dg-error "deleted function" "" { target *-*-* } 180 }
 | ||||
| // { dg-error "deleted function" "" { target *-*-* } 190 }
 | ||||
|  |  | |||
|  | @ -3,7 +3,7 @@ | |||
| // { dg-require-cstdint "" }
 | ||||
| // { dg-require-gthreads "" }
 | ||||
| 
 | ||||
| // Copyright (C) 2008 Free Software Foundation, Inc.
 | ||||
| // Copyright (C) 2008, 2009 Free Software Foundation, Inc.
 | ||||
| //
 | ||||
| // This file is part of the GNU ISO C++ Library.  This library is free
 | ||||
| // software; you can redistribute it and/or modify it under the
 | ||||
|  | @ -41,4 +41,4 @@ void test01() | |||
| } | ||||
| 
 | ||||
| // { dg-error "used here" "" { target *-*-* } 40 } 
 | ||||
| // { dg-error "deleted function" "" { target *-*-* } 179 }
 | ||||
| // { dg-error "deleted function" "" { target *-*-* } 189 }
 | ||||
|  |  | |||
|  | @ -0,0 +1,34 @@ | |||
| // { dg-do run { target *-*-freebsd* *-*-netbsd* *-*-linux* *-*-solaris* *-*-cygwin *-*-darwin* alpha*-*-osf* mips-sgi-irix6* } }
 | ||||
| // { dg-options " -std=gnu++0x -pthread" { target *-*-freebsd* *-*-netbsd* *-*-linux* alpha*-*-osf* mips-sgi-irix6* } }
 | ||||
| // { dg-options " -std=gnu++0x -pthreads" { target *-*-solaris* } }
 | ||||
| // { dg-options " -std=gnu++0x " { target *-*-cygwin *-*-darwin* } }
 | ||||
| // { dg-require-cstdint "" }
 | ||||
| // { dg-require-gthreads "" }
 | ||||
| 
 | ||||
| // Copyright (C) 2009 Free Software Foundation, Inc.
 | ||||
| //
 | ||||
| // This file is part of the GNU ISO C++ Library.  This library is free
 | ||||
| // software; you can redistribute it and/or modify it under the
 | ||||
| // terms of the GNU General Public License as published by the
 | ||||
| // Free Software Foundation; either version 2, or (at your option)
 | ||||
| // any later version.
 | ||||
| 
 | ||||
| // This library is distributed in the hope that it will be useful,
 | ||||
| // but WITHOUT ANY WARRANTY; without even the implied warranty of
 | ||||
| // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | ||||
| // GNU General Public License for more details.
 | ||||
| 
 | ||||
| // You should have received a copy of the GNU General Public License along
 | ||||
| // with this library; see the file COPYING.  If not, write to the Free
 | ||||
| // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
 | ||||
| // USA.
 | ||||
| 
 | ||||
| #include <thread/all.h> | ||||
| #include <mutex> | ||||
| 
 | ||||
| int main() | ||||
| { | ||||
|   typedef std::timed_mutex test_type; | ||||
|   __gnu_test::compare_type_to_native_type_sizes<test_type>(); | ||||
|   return 0; | ||||
| } | ||||
|  | @ -0,0 +1,66 @@ | |||
| // -*- C++ -*-
 | ||||
| // Utilities for testing threads for the C++ library testsuite.
 | ||||
| //
 | ||||
| // Copyright (C) 2009 Free Software Foundation, Inc.
 | ||||
| //
 | ||||
| // This file is part of the GNU ISO C++ Library.  This library is free
 | ||||
| // software; you can redistribute it and/or modify it under the
 | ||||
| // terms of the GNU General Public License as published by the
 | ||||
| // Free Software Foundation; either version 2, or (at your option)
 | ||||
| // any later version.
 | ||||
| //
 | ||||
| // This library is distributed in the hope that it will be useful,
 | ||||
| // but WITHOUT ANY WARRANTY; without even the implied warranty of
 | ||||
| // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | ||||
| // GNU General Public License for more details.
 | ||||
| //
 | ||||
| // You should have received a copy of the GNU General Public License along
 | ||||
| // with this library; see the file COPYING.  If not, write to the Free
 | ||||
| // Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
 | ||||
| // USA.
 | ||||
| //
 | ||||
| // As a special exception, you may use this file as part of a free software
 | ||||
| // library without restriction.  Specifically, if other files instantiate
 | ||||
| // templates or use macros or inline functions from this file, or you compile
 | ||||
| // this file and link it with other files to produce an executable, this
 | ||||
| // file does not by itself cause the resulting executable to be covered by
 | ||||
| // the GNU General Public License.  This exception does not however
 | ||||
| // invalidate any other reasons why the executable file might be covered by
 | ||||
| // the GNU General Public License.
 | ||||
| 
 | ||||
| #ifndef _GLIBCXX_TESTSUITE_THREAD_H | ||||
| #define _GLIBCXX_TESTSUITE_THREAD_H | ||||
| 
 | ||||
| #include <sstream> | ||||
| #include <stdexcept> | ||||
| #include <type_traits> | ||||
| 
 | ||||
| // C++0x only.
 | ||||
| namespace __gnu_test | ||||
| {   | ||||
|   // Assume _Tp::native_handle_type.
 | ||||
|   template<typename _Tp> | ||||
|     void | ||||
|     compare_type_to_native_type_sizes() | ||||
|     { | ||||
|       typedef _Tp test_type; | ||||
|       typedef typename test_type::native_handle_type native_handle_type; | ||||
| 
 | ||||
|       int st = sizeof(test_type); | ||||
| 
 | ||||
|       // Remove possible pointer type.
 | ||||
|       int snt = sizeof(typename std::remove_pointer<native_handle_type>::type); | ||||
|        | ||||
|       if (st != snt) | ||||
| 	{ | ||||
| 	  std::ostringstream s; | ||||
| 	  s << std::endl; | ||||
| 	  s << "size of _Tp: " << st << std::endl; | ||||
| 	  s << "size of *(_Tp::native_handle_type): " << snt << std::endl; | ||||
| 	  throw std::runtime_error(s.str()); | ||||
| 	} | ||||
|     } | ||||
| } // namespace __gnu_test
 | ||||
| 
 | ||||
| #endif // _GLIBCXX_TESTSUITE_THREAD_H
 | ||||
| 
 | ||||
		Loading…
	
		Reference in New Issue
	
	 bkoz
						bkoz