diff options
author | bkoz <bkoz@138bc75d-0d04-0410-961f-82ee72b054a4> | 2004-09-01 22:17:00 +0000 |
---|---|---|
committer | bkoz <bkoz@138bc75d-0d04-0410-961f-82ee72b054a4> | 2004-09-01 22:17:00 +0000 |
commit | 8ca34f016893950ea5f922962a7a9a2e78d10a85 (patch) | |
tree | 011bcfe52cc2afab1d0b8cb19946c66ceddd599d /libstdc++-v3/testsuite/ext/mt_allocator/tune-1.cc | |
parent | 197f99883d299fc7e68e0f92f798c90319ec1150 (diff) | |
download | ppe42-gcc-8ca34f016893950ea5f922962a7a9a2e78d10a85.tar.gz ppe42-gcc-8ca34f016893950ea5f922962a7a9a2e78d10a85.zip |
2004-09-01 Benjamin Kosnik <bkoz@redhat.com>
PR libstdc++/16614
* include/ext/mt_allocator.h (__mt_base): Not type dependent,
split into..
(__pool): New, specialize.
(__common_pool): New, static bits here.
(__per_type_pool): New, and here.
(__mt_alloc_base): New.
(__mt_alloc): Add template parameter, inherit from it.
* src/allocator.cc: Split this...
* src/allocator-inst.cc: And this...
* src/pool_allocator.cc: ...into this.
* src/mt_allocator.cc: ... and this. Add definitions for
__mt_base.
* src/Makefile.am (sources): Split allocator.cc to
pool_allocator.cc and mt_allocator.cc.
* src/Makefile.in: Regenerate.
* config/linker-map.gnu: Add symbols.
* docs/html/ext/mt_allocator.html: Document new design.
* testsuite/ext/mt_allocator/tune-1.cc: New.
* testsuite/ext/mt_allocator/tune-2.cc: New.
* testsuite/ext/mt_allocator/tune-3.cc: New.
* testsuite/ext/mt_allocator/tune-4.cc: New.
* testsuite/testsuite_allocator.h (__gnu_test::check_new): New.
* testsuite/ext/allocators.cc: Use check_new, split into...
* testsuite/ext/mt_allocator/check_new.cc: this.
* testsuite/ext/pool_allocator/check_new.cc: this.
* testsuite/ext/malloc_allocator/check_new.cc: this.
* testsuite/ext/debug_allocator/check_new.cc: this.
* testsuite/ext/mt_allocator/instantiate.cc: this.
* testsuite/ext/pool_allocator/instantiate.cc: this.
* testsuite/ext/malloc_allocator/instantiate.cc: this.
* testsuite/ext/debug_allocator/instantiate.cc: this.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@86936 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'libstdc++-v3/testsuite/ext/mt_allocator/tune-1.cc')
-rw-r--r-- | libstdc++-v3/testsuite/ext/mt_allocator/tune-1.cc | 69 |
1 files changed, 69 insertions, 0 deletions
diff --git a/libstdc++-v3/testsuite/ext/mt_allocator/tune-1.cc b/libstdc++-v3/testsuite/ext/mt_allocator/tune-1.cc new file mode 100644 index 00000000000..d5769fce026 --- /dev/null +++ b/libstdc++-v3/testsuite/ext/mt_allocator/tune-1.cc @@ -0,0 +1,69 @@ +// 2004-08-25 Benjamin Kosnik <bkoz@redhat.com> +// +// Copyright (C) 2004 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, 59 Temple Place - Suite 330, Boston, MA 02111-1307, +// USA. + +#include <cassert> +#include <memory> +#include <ext/mt_allocator.h> + +struct pod +{ + int i; +}; + +// Tune characteristics. +// __common_pool_policy +void test01() +{ + typedef pod value_type; +#ifdef __GTHREADS + typedef __gnu_cxx::__common_pool_policy<true> policy_type; +#else + typedef __gnu_cxx::__common_pool_policy<false> policy_type; +#endif + typedef __gnu_cxx::__mt_alloc<value_type, policy_type> allocator_type; + typedef __gnu_cxx::__pool_base::_Tune tune_type; + + tune_type t_default; + tune_type t_opt(16, 5120, 32, 5120, 20, 10, false); + tune_type t_single(16, 5120, 32, 5120, 1, 10, false); + + allocator_type a; + tune_type t1 = a._M_get_options(); + assert(t1._M_align == t_default._M_align); + a._M_set_options(t_opt); + tune_type t2 = a._M_get_options(); + assert(t1._M_align != t2._M_align); + + allocator_type::pointer p1 = a.allocate(128); + allocator_type::pointer p2 = a.allocate(5128); + a._M_set_options(t_single); + t1 = a._M_get_options(); + assert(t1._M_max_threads != t_single._M_max_threads); + assert(t1._M_max_threads == t_opt._M_max_threads); + + a.deallocate(p1, 128); + a.deallocate(p2, 5128); +} + +int main() +{ + test01(); + return 0; +} |