mirror of git://gcc.gnu.org/git/gcc.git
random.h (random_device): Move implementation to...
* include/bits/random.h (random_device): Move implementation to... * src/c++11/random.cc: ...here. New file. * config/abi/pre/gnu.ver: Add new version GLIBCXX_3.4.18. Export std::random_device::* symbols. * config/abi/post/x86_64-linux-gnu/baseline_symbols.txt: Generated. * src/c++11/Makefile.am (sources): Add random.cc. * src/c++11/Makefile.in: Regenerated. From-SVN: r190787
This commit is contained in:
parent
1dd5907e5c
commit
a8c3f4c972
|
|
@ -1485,6 +1485,10 @@ FUNC:_ZNSt13basic_ostreamIwSt11char_traitsIwEElsEs@@GLIBCXX_3.4
|
||||||
FUNC:_ZNSt13basic_ostreamIwSt11char_traitsIwEElsEt@@GLIBCXX_3.4
|
FUNC:_ZNSt13basic_ostreamIwSt11char_traitsIwEElsEt@@GLIBCXX_3.4
|
||||||
FUNC:_ZNSt13basic_ostreamIwSt11char_traitsIwEElsEx@@GLIBCXX_3.4
|
FUNC:_ZNSt13basic_ostreamIwSt11char_traitsIwEElsEx@@GLIBCXX_3.4
|
||||||
FUNC:_ZNSt13basic_ostreamIwSt11char_traitsIwEElsEy@@GLIBCXX_3.4
|
FUNC:_ZNSt13basic_ostreamIwSt11char_traitsIwEElsEy@@GLIBCXX_3.4
|
||||||
|
FUNC:_ZNSt13random_device14_M_init_pretr1ERKSs@@GLIBCXX_3.4.18
|
||||||
|
FUNC:_ZNSt13random_device16_M_getval_pretr1Ev@@GLIBCXX_3.4.18
|
||||||
|
FUNC:_ZNSt13random_device7_M_initERKSs@@GLIBCXX_3.4.18
|
||||||
|
FUNC:_ZNSt13random_device9_M_getvalEv@@GLIBCXX_3.4.18
|
||||||
FUNC:_ZNSt13runtime_errorC1ERKSs@@GLIBCXX_3.4
|
FUNC:_ZNSt13runtime_errorC1ERKSs@@GLIBCXX_3.4
|
||||||
FUNC:_ZNSt13runtime_errorC2ERKSs@@GLIBCXX_3.4
|
FUNC:_ZNSt13runtime_errorC2ERKSs@@GLIBCXX_3.4
|
||||||
FUNC:_ZNSt13runtime_errorD0Ev@@GLIBCXX_3.4
|
FUNC:_ZNSt13runtime_errorD0Ev@@GLIBCXX_3.4
|
||||||
|
|
@ -2502,6 +2506,7 @@ OBJECT:0:GLIBCXX_3.4.14
|
||||||
OBJECT:0:GLIBCXX_3.4.15
|
OBJECT:0:GLIBCXX_3.4.15
|
||||||
OBJECT:0:GLIBCXX_3.4.16
|
OBJECT:0:GLIBCXX_3.4.16
|
||||||
OBJECT:0:GLIBCXX_3.4.17
|
OBJECT:0:GLIBCXX_3.4.17
|
||||||
|
OBJECT:0:GLIBCXX_3.4.18
|
||||||
OBJECT:0:GLIBCXX_3.4.2
|
OBJECT:0:GLIBCXX_3.4.2
|
||||||
OBJECT:0:GLIBCXX_3.4.3
|
OBJECT:0:GLIBCXX_3.4.3
|
||||||
OBJECT:0:GLIBCXX_3.4.4
|
OBJECT:0:GLIBCXX_3.4.4
|
||||||
|
|
@ -3683,3 +3688,5 @@ OBJECT:96:_ZTVSt12ctype_bynameIcE@@GLIBCXX_3.4
|
||||||
OBJECT:96:_ZTVSt5ctypeIcE@@GLIBCXX_3.4
|
OBJECT:96:_ZTVSt5ctypeIcE@@GLIBCXX_3.4
|
||||||
OBJECT:96:_ZTVSt7num_putIcSt19ostreambuf_iteratorIcSt11char_traitsIcEEE@@GLIBCXX_3.4
|
OBJECT:96:_ZTVSt7num_putIcSt19ostreambuf_iteratorIcSt11char_traitsIcEEE@@GLIBCXX_3.4
|
||||||
OBJECT:96:_ZTVSt7num_putIwSt19ostreambuf_iteratorIwSt11char_traitsIwEEE@@GLIBCXX_3.4
|
OBJECT:96:_ZTVSt7num_putIwSt19ostreambuf_iteratorIwSt11char_traitsIwEEE@@GLIBCXX_3.4
|
||||||
|
TLS:8:_ZSt11__once_call@@GLIBCXX_3.4.11
|
||||||
|
TLS:8:_ZSt15__once_callable@@GLIBCXX_3.4.11
|
||||||
|
|
|
||||||
|
|
@ -1321,6 +1321,17 @@ GLIBCXX_3.4.17 {
|
||||||
|
|
||||||
} GLIBCXX_3.4.16;
|
} GLIBCXX_3.4.16;
|
||||||
|
|
||||||
|
GLIBCXX_3.4.18 {
|
||||||
|
global:
|
||||||
|
|
||||||
|
# Names inside the 'extern' block are demangled names.
|
||||||
|
extern "C++"
|
||||||
|
{
|
||||||
|
std::random_device::*;
|
||||||
|
};
|
||||||
|
|
||||||
|
} GLIBCXX_3.4.17;
|
||||||
|
|
||||||
# Symbols in the support library (libsupc++) have their own tag.
|
# Symbols in the support library (libsupc++) have their own tag.
|
||||||
CXXABI_1.3 {
|
CXXABI_1.3 {
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1575,39 +1575,19 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
|
||||||
#ifdef _GLIBCXX_USE_RANDOM_TR1
|
#ifdef _GLIBCXX_USE_RANDOM_TR1
|
||||||
|
|
||||||
explicit
|
explicit
|
||||||
random_device(const std::string& __token = "/dev/urandom")
|
random_device(const std::string& __token = "default")
|
||||||
{
|
{
|
||||||
if ((__token != "/dev/urandom" && __token != "/dev/random")
|
_M_init(__token);
|
||||||
|| !(_M_file = std::fopen(__token.c_str(), "rb")))
|
|
||||||
std::__throw_runtime_error(__N("random_device::"
|
|
||||||
"random_device(const std::string&)"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
~random_device()
|
~random_device()
|
||||||
{ std::fclose(_M_file); }
|
{ _M_fini(); }
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
|
||||||
explicit
|
explicit
|
||||||
random_device(const std::string& __token = "mt19937")
|
random_device(const std::string& __token = "mt19937")
|
||||||
: _M_mt(_M_strtoul(__token)) { }
|
{ return _M_init_pretr1(__token); }
|
||||||
|
|
||||||
private:
|
|
||||||
static unsigned long
|
|
||||||
_M_strtoul(const std::string& __str)
|
|
||||||
{
|
|
||||||
unsigned long __ret = 5489UL;
|
|
||||||
if (__str != "mt19937")
|
|
||||||
{
|
|
||||||
const char* __nptr = __str.c_str();
|
|
||||||
char* __endptr;
|
|
||||||
__ret = std::strtoul(__nptr, &__endptr, 0);
|
|
||||||
if (*__nptr == '\0' || *__endptr != '\0')
|
|
||||||
std::__throw_runtime_error(__N("random_device::_M_strtoul"
|
|
||||||
"(const std::string&)"));
|
|
||||||
}
|
|
||||||
return __ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
|
|
@ -1629,12 +1609,9 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
|
||||||
operator()()
|
operator()()
|
||||||
{
|
{
|
||||||
#ifdef _GLIBCXX_USE_RANDOM_TR1
|
#ifdef _GLIBCXX_USE_RANDOM_TR1
|
||||||
result_type __ret;
|
return this->_M_getval();
|
||||||
std::fread(reinterpret_cast<void*>(&__ret), sizeof(result_type),
|
|
||||||
1, _M_file);
|
|
||||||
return __ret;
|
|
||||||
#else
|
#else
|
||||||
return _M_mt();
|
return this->_M_getval_pretr1();
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -1644,11 +1621,18 @@ _GLIBCXX_BEGIN_NAMESPACE_VERSION
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
#ifdef _GLIBCXX_USE_RANDOM_TR1
|
void _M_init(const std::string& __token);
|
||||||
|
void _M_init_pretr1(const std::string& __token);
|
||||||
|
void _M_fini();
|
||||||
|
|
||||||
|
result_type _M_getval();
|
||||||
|
result_type _M_getval_pretr1();
|
||||||
|
|
||||||
|
union
|
||||||
|
{
|
||||||
FILE* _M_file;
|
FILE* _M_file;
|
||||||
#else
|
|
||||||
mt19937 _M_mt;
|
mt19937 _M_mt;
|
||||||
#endif
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
/* @} */ // group random_generators
|
/* @} */ // group random_generators
|
||||||
|
|
|
||||||
|
|
@ -41,6 +41,7 @@ sources = \
|
||||||
limits.cc \
|
limits.cc \
|
||||||
mutex.cc \
|
mutex.cc \
|
||||||
placeholders.cc \
|
placeholders.cc \
|
||||||
|
random.cc \
|
||||||
regex.cc \
|
regex.cc \
|
||||||
shared_ptr.cc \
|
shared_ptr.cc \
|
||||||
system_error.cc \
|
system_error.cc \
|
||||||
|
|
|
||||||
|
|
@ -1,9 +1,9 @@
|
||||||
# Makefile.in generated by automake 1.11.1 from Makefile.am.
|
# Makefile.in generated by automake 1.11.3 from Makefile.am.
|
||||||
# @configure_input@
|
# @configure_input@
|
||||||
|
|
||||||
# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002,
|
# Copyright (C) 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001, 2002,
|
||||||
# 2003, 2004, 2005, 2006, 2007, 2008, 2009 Free Software Foundation,
|
# 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011 Free Software
|
||||||
# Inc.
|
# Foundation, Inc.
|
||||||
# This Makefile.in is free software; the Free Software Foundation
|
# This Makefile.in is free software; the Free Software Foundation
|
||||||
# gives unlimited permission to copy and/or distribute it,
|
# gives unlimited permission to copy and/or distribute it,
|
||||||
# with or without modifications, as long as this notice is preserved.
|
# with or without modifications, as long as this notice is preserved.
|
||||||
|
|
@ -68,8 +68,8 @@ LTLIBRARIES = $(noinst_LTLIBRARIES)
|
||||||
libc__11convenience_la_LIBADD =
|
libc__11convenience_la_LIBADD =
|
||||||
am__objects_1 = chrono.lo condition_variable.lo debug.lo \
|
am__objects_1 = chrono.lo condition_variable.lo debug.lo \
|
||||||
functexcept.lo functional.lo future.lo hash_c++0x.lo \
|
functexcept.lo functional.lo future.lo hash_c++0x.lo \
|
||||||
hashtable_c++0x.lo limits.lo mutex.lo placeholders.lo regex.lo \
|
hashtable_c++0x.lo limits.lo mutex.lo placeholders.lo \
|
||||||
shared_ptr.lo system_error.lo thread.lo
|
random.lo regex.lo shared_ptr.lo system_error.lo thread.lo
|
||||||
@ENABLE_EXTERN_TEMPLATE_TRUE@am__objects_2 = fstream-inst.lo \
|
@ENABLE_EXTERN_TEMPLATE_TRUE@am__objects_2 = fstream-inst.lo \
|
||||||
@ENABLE_EXTERN_TEMPLATE_TRUE@ string-inst.lo wstring-inst.lo
|
@ENABLE_EXTERN_TEMPLATE_TRUE@ string-inst.lo wstring-inst.lo
|
||||||
am_libc__11convenience_la_OBJECTS = $(am__objects_1) $(am__objects_2)
|
am_libc__11convenience_la_OBJECTS = $(am__objects_1) $(am__objects_2)
|
||||||
|
|
@ -309,6 +309,7 @@ sources = \
|
||||||
limits.cc \
|
limits.cc \
|
||||||
mutex.cc \
|
mutex.cc \
|
||||||
placeholders.cc \
|
placeholders.cc \
|
||||||
|
random.cc \
|
||||||
regex.cc \
|
regex.cc \
|
||||||
shared_ptr.cc \
|
shared_ptr.cc \
|
||||||
system_error.cc \
|
system_error.cc \
|
||||||
|
|
@ -404,6 +405,7 @@ Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
|
||||||
echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \
|
echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \
|
||||||
cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \
|
cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \
|
||||||
esac;
|
esac;
|
||||||
|
$(top_srcdir)/fragment.am:
|
||||||
|
|
||||||
$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
|
$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
|
||||||
cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
|
cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
|
||||||
|
|
@ -422,7 +424,7 @@ clean-noinstLTLIBRARIES:
|
||||||
echo "rm -f \"$${dir}/so_locations\""; \
|
echo "rm -f \"$${dir}/so_locations\""; \
|
||||||
rm -f "$${dir}/so_locations"; \
|
rm -f "$${dir}/so_locations"; \
|
||||||
done
|
done
|
||||||
libc++11convenience.la: $(libc__11convenience_la_OBJECTS) $(libc__11convenience_la_DEPENDENCIES)
|
libc++11convenience.la: $(libc__11convenience_la_OBJECTS) $(libc__11convenience_la_DEPENDENCIES) $(EXTRA_libc__11convenience_la_DEPENDENCIES)
|
||||||
$(CXXLINK) $(libc__11convenience_la_OBJECTS) $(libc__11convenience_la_LIBADD) $(LIBS)
|
$(CXXLINK) $(libc__11convenience_la_OBJECTS) $(libc__11convenience_la_LIBADD) $(LIBS)
|
||||||
|
|
||||||
mostlyclean-compile:
|
mostlyclean-compile:
|
||||||
|
|
@ -511,10 +513,15 @@ install-am: all-am
|
||||||
|
|
||||||
installcheck: installcheck-am
|
installcheck: installcheck-am
|
||||||
install-strip:
|
install-strip:
|
||||||
|
if test -z '$(STRIP)'; then \
|
||||||
$(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
|
$(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
|
||||||
install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
|
install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
|
||||||
`test -z '$(STRIP)' || \
|
install; \
|
||||||
echo "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'"` install
|
else \
|
||||||
|
$(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
|
||||||
|
install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
|
||||||
|
"INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \
|
||||||
|
fi
|
||||||
mostlyclean-generic:
|
mostlyclean-generic:
|
||||||
|
|
||||||
clean-generic:
|
clean-generic:
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,147 @@
|
||||||
|
// random -*- C++ -*-
|
||||||
|
|
||||||
|
// Copyright (C) 2012 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 3, 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.
|
||||||
|
|
||||||
|
// Under Section 7 of GPL version 3, you are granted additional
|
||||||
|
// permissions described in the GCC Runtime Library Exception, version
|
||||||
|
// 3.1, as published by the Free Software Foundation.
|
||||||
|
|
||||||
|
// You should have received a copy of the GNU General Public License and
|
||||||
|
// a copy of the GCC Runtime Library Exception along with this program;
|
||||||
|
// see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
|
||||||
|
// <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
#include <random>
|
||||||
|
|
||||||
|
#if defined __i386__ || defined __x86_64__
|
||||||
|
# include <cpuid.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
namespace std _GLIBCXX_VISIBILITY(default)
|
||||||
|
{
|
||||||
|
|
||||||
|
namespace
|
||||||
|
{
|
||||||
|
static unsigned long
|
||||||
|
_M_strtoul(const std::string& __str)
|
||||||
|
{
|
||||||
|
unsigned long __ret = 5489UL;
|
||||||
|
if (__str != "mt19937")
|
||||||
|
{
|
||||||
|
const char* __nptr = __str.c_str();
|
||||||
|
char* __endptr;
|
||||||
|
__ret = std::strtoul(__nptr, &__endptr, 0);
|
||||||
|
if (*__nptr == '\0' || *__endptr != '\0')
|
||||||
|
std::__throw_runtime_error(__N("random_device::_M_strtoul"
|
||||||
|
"(const std::string&)"));
|
||||||
|
}
|
||||||
|
return __ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
#if defined __i386__ || defined __x86_64__
|
||||||
|
unsigned int
|
||||||
|
__attribute__ ((target("rdrnd")))
|
||||||
|
__x86_rdrand(void)
|
||||||
|
{
|
||||||
|
unsigned int retries = 100;
|
||||||
|
unsigned int val;
|
||||||
|
|
||||||
|
while (__builtin_ia32_rdrand32_step(&val) == 0)
|
||||||
|
if (--retries == 0)
|
||||||
|
std::__throw_runtime_error(__N("random_device::__x86_rdrand(void)"));
|
||||||
|
|
||||||
|
return val;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void
|
||||||
|
random_device::_M_init(const std::string& token)
|
||||||
|
{
|
||||||
|
const char *fname = token.c_str();
|
||||||
|
|
||||||
|
if (token == "default")
|
||||||
|
{
|
||||||
|
#if defined __i386__ || defined __x86_64__
|
||||||
|
unsigned int eax, ebx, ecx, edx;
|
||||||
|
__cpuid(0, eax, ebx, ecx, edx);
|
||||||
|
// Check for "GenuineIntel"
|
||||||
|
if (ebx == 0x756e6547 && ecx == 0x6c65746e && edx == 0x49656e69)
|
||||||
|
{
|
||||||
|
__cpuid(1, eax, ebx, ecx, edx);
|
||||||
|
if (ecx & bit_RDRND)
|
||||||
|
{
|
||||||
|
_M_file = nullptr;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
fname = "/dev/urandom";
|
||||||
|
}
|
||||||
|
else if (token != "/dev/urandom" && token != "/dev/random")
|
||||||
|
fail:
|
||||||
|
std::__throw_runtime_error(__N("random_device::"
|
||||||
|
"random_device(const std::string&)"));
|
||||||
|
|
||||||
|
_M_file = std::fopen(fname, "rb");
|
||||||
|
if (! _M_file)
|
||||||
|
goto fail;
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
random_device::_M_init_pretr1(const std::string& token)
|
||||||
|
|
||||||
|
{
|
||||||
|
_M_mt.seed(_M_strtoul(token));
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
random_device::_M_fini()
|
||||||
|
{
|
||||||
|
if (_M_file)
|
||||||
|
std::fclose(_M_file);
|
||||||
|
}
|
||||||
|
|
||||||
|
random_device::result_type
|
||||||
|
random_device::_M_getval()
|
||||||
|
{
|
||||||
|
#if (defined __i386__ || defined __x86_64__)
|
||||||
|
if (! _M_file)
|
||||||
|
return __x86_rdrand();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
result_type __ret;
|
||||||
|
std::fread(reinterpret_cast<void*>(&__ret), sizeof(result_type),
|
||||||
|
1, _M_file);
|
||||||
|
return __ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
random_device::result_type
|
||||||
|
random_device::_M_getval_pretr1()
|
||||||
|
{
|
||||||
|
return _M_mt();
|
||||||
|
}
|
||||||
|
|
||||||
|
template class mersenne_twister_engine<
|
||||||
|
uint_fast32_t,
|
||||||
|
32, 624, 397, 31,
|
||||||
|
0x9908b0dfUL, 11,
|
||||||
|
0xffffffffUL, 7,
|
||||||
|
0x9d2c5680UL, 15,
|
||||||
|
0xefc60000UL, 18, 1812433253UL>;
|
||||||
|
|
||||||
|
}
|
||||||
Loading…
Reference in New Issue