diff options
Diffstat (limited to 'pmt/src')
-rw-r--r-- | pmt/src/lib/Makefile.am | 8 | ||||
-rw-r--r-- | pmt/src/lib/pmt_pool.cc | 13 | ||||
-rw-r--r-- | pmt/src/lib/pmt_pool.h | 9 |
3 files changed, 15 insertions, 15 deletions
diff --git a/pmt/src/lib/Makefile.am b/pmt/src/lib/Makefile.am index 32e5210d5..a510f4e0b 100644 --- a/pmt/src/lib/Makefile.am +++ b/pmt/src/lib/Makefile.am @@ -1,5 +1,5 @@ # -# Copyright 2006,2008 Free Software Foundation, Inc. +# Copyright 2006,2008,2009 Free Software Foundation, Inc. # # This file is part of GNU Radio # @@ -21,7 +21,7 @@ include $(top_srcdir)/Makefile.common -AM_CPPFLAGS = $(DEFINES) $(OMNITHREAD_INCLUDES) $(BOOST_CPPFLAGS) \ +AM_CPPFLAGS = $(DEFINES) $(BOOST_CPPFLAGS) \ $(CPPUNIT_INCLUDES) $(WITH_INCLUDES) TESTS = test_pmt @@ -63,11 +63,11 @@ libpmt_la_SOURCES = \ pmt_unv.cc # magic flags -libpmt_la_LDFLAGS = $(NO_UNDEFINED) +libpmt_la_LDFLAGS = $(NO_UNDEFINED) $(BOOST_LDFLAGS) # link the library against the c++ standard library libpmt_la_LIBADD = \ - $(OMNITHREAD_LA) \ + $(BOOST_THREAD_LIB) \ -lstdc++ include_HEADERS = \ diff --git a/pmt/src/lib/pmt_pool.cc b/pmt/src/lib/pmt_pool.cc index 05d9c005b..05a7f5900 100644 --- a/pmt/src/lib/pmt_pool.cc +++ b/pmt/src/lib/pmt_pool.cc @@ -1,6 +1,6 @@ /* -*- c++ -*- */ /* - * Copyright 2007 Free Software Foundation, Inc. + * Copyright 2007,2009 Free Software Foundation, Inc. * * This file is part of GNU Radio * @@ -34,8 +34,7 @@ ROUNDUP(size_t x, size_t stride) pmt_pool::pmt_pool(size_t itemsize, size_t alignment, size_t allocation_size, size_t max_items) - : d_cond(&d_mutex), - d_itemsize(ROUNDUP(itemsize, alignment)), + : d_itemsize(ROUNDUP(itemsize, alignment)), d_alignment(alignment), d_allocation_size(std::max(allocation_size, 16 * itemsize)), d_max_items(max_items), d_n_items(0), @@ -53,12 +52,12 @@ pmt_pool::~pmt_pool() void * pmt_pool::malloc() { - omni_mutex_lock l(d_mutex); + scoped_lock guard(d_mutex); item *p; if (d_max_items != 0){ while (d_n_items >= d_max_items) - d_cond.wait(); + d_cond.wait(guard); } if (d_freelist){ // got something? @@ -98,12 +97,12 @@ pmt_pool::free(void *foo) if (!foo) return; - omni_mutex_lock l(d_mutex); + scoped_lock guard(d_mutex); item *p = (item *) foo; p->d_next = d_freelist; d_freelist = p; d_n_items--; if (d_max_items != 0) - d_cond.signal(); + d_cond.notify_one(); } diff --git a/pmt/src/lib/pmt_pool.h b/pmt/src/lib/pmt_pool.h index dd63d44a6..8004a65e4 100644 --- a/pmt/src/lib/pmt_pool.h +++ b/pmt/src/lib/pmt_pool.h @@ -1,6 +1,6 @@ /* -*- c++ -*- */ /* - * Copyright 2007 Free Software Foundation, Inc. + * Copyright 2007,2009 Free Software Foundation, Inc. * * This file is part of GNU Radio * @@ -22,8 +22,8 @@ #define INCLUDED_PMT_POOL_H #include <cstddef> -#include <gnuradio/omnithread.h> #include <vector> +#include <boost/thread.hpp> /*! * \brief very simple thread-safe fixed-size allocation pool @@ -37,8 +37,9 @@ class pmt_pool { struct item *d_next; }; - omni_mutex d_mutex; - omni_condition d_cond; + typedef boost::unique_lock<boost::mutex> scoped_lock; + mutable boost::mutex d_mutex; + boost::condition_variable d_cond; size_t d_itemsize; size_t d_alignment; |