Skip to content
Snippets Groups Projects
  1. Mar 25, 2020
  2. Nov 19, 2019
  3. Jan 15, 2019
  4. Jan 14, 2019
  5. Jul 21, 2016
  6. Nov 10, 2015
  7. May 09, 2013
  8. Mar 29, 2013
  9. Feb 28, 2013
  10. Jan 08, 2013
    • Richard Linden's avatar
      SH-3468 WIP add memory tracking base class · 3c341a11
      Richard Linden authored
      more fixes for unit test crashes
      added llcommon initialization/teardown for unit tests
      that indirectly trigger lltrace
      changed access of atomic refcount to use preincrement/decrement
      operators to reflect desired semantics
      always call apr_initialize in LLCommon::initClass, even
      if already initialized...apr does internal reference counting
      to keep things straight
      3c341a11
  11. Jan 07, 2013
    • Richard Linden's avatar
      SH-3468 WIP add memory tracking base class · 68413515
      Richard Linden authored
      fix for unit test failures...cleanup apr without destroying
      pools, allowing LLProxy to clean itself up as a singleton (and
      avoiding spurious dependencies associated with manually destorying
      singletons that rely on apr pools)
      68413515
  12. Dec 23, 2012
  13. Dec 21, 2012
  14. Dec 18, 2012
  15. Dec 01, 2012
  16. Nov 15, 2012
  17. Nov 07, 2012
    • Richard Linden's avatar
      SH-3499 WIP Ensure asset stats output is correct · 860ff2f7
      Richard Linden authored
      fixed trace data gathering and routing from background thread
      simplified slave->master thread communication (eliminated redundant recording and proxy object)
      improved performance of fast timer data gathering (slow iterators)
      860ff2f7
  18. Oct 02, 2012
  19. Oct 01, 2012
  20. Sep 30, 2012
  21. Sep 26, 2012
  22. Sep 24, 2012
  23. Jun 12, 2012
  24. Oct 14, 2011
  25. Oct 04, 2011
  26. Feb 05, 2011
    • Aleric Inglewood's avatar
      Introduces a LLThreadLocalData class that can be · ef490e30
      Aleric Inglewood authored
      accessed through the static LLThread::tldata().
      Currently this object contains two (public) thread-local
      objects: a LLAPRRootPool and a LLVolatileAPRPool.
      
      The first is the general memory pool used by this thread
      (and this thread alone), while the second is intended
      for short lived memory allocations (needed for APR).
      The advantages of not mixing those two is that the latter
      is used most frequently, and as a result of it's nature
      can be destroyed and reconstructed on a "regular" basis.
      
      This patch adds LLAPRPool (completely replacing the old one),
      which is a wrapper around apr_pool_t* and has complete
      thread-safity checking.
      
      Whenever an apr call requires memory for some resource,
      a memory pool in the form of an LLAPRPool object can
      be created with the same life-time as this resource;
      assuring clean up of the memory no sooner, but also
      not much later than the life-time of the resource
      that needs the memory.
      
      Many, many function calls and constructors had the
      pool parameter simply removed (it is no longer the
      concern of the developer, if you don't write code
      that actually does an libapr call then you are no
      longer bothered with memory pools at all).
      
      However, I kept the notion of short-lived and
      long-lived allocations alive (see my remark in
      the jira here: https://jira.secondlife.com/browse/STORM-864?focusedCommentId=235356&page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel#comment-235356
      which requires that the LLAPRFile API needs
      to allow the user to specify how long they
      think a file will stay open. By choosing
      'short_lived' as default for the constructor
      that immediately opens a file, the number of
      instances where this needs to be specified is
      drastically reduced however (obviously, any
      automatic LLAPRFile is short lived).
      
      ***
      
      Addressed Boroondas remarks in https://codereview.secondlife.com/r/99/
      regarding (doxygen) comments. This patch effectively only changes comments.
      
      Includes some 'merge' stuff that ended up in llvocache.cpp
      (while starting as a bug fix, now only resulting in a cleanup).
      
      ***
      
      Added comment 'The use of apr_pool_t is OK here'.
      
      Added this comment on every line where apr_pool_t
      is correctly being used.
      
      This should make it easier to spot (future) errors
      where someone started to use apr_pool_t; you can
      just grep all sources for 'apr_pool_t' and immediately
      see where it's being used while LLAPRPool should
      have been used.
      
      Note that merging this patch is very easy:
      If there are no other uses of apr_pool_t in the code
      (one grep) and it compiles, then it will work.
      
      ***
      
      Second Merge (needed to remove 'delete mCreationMutex'
      from LLImageDecodeThread::~LLImageDecodeThread).
      
      ***
      
      Added back #include <apr_pools.h>.
      
      Apparently that is needed on libapr version 1.2.8.,
      the version used by Linden Lab, for calls to
      apr_queue_*. This is a bug in libapr (we also
      include <apr_queue.h>, that is fixed in (at least) 1.3.7.
      
      Note that 1.2.8 is VERY old. Even 1.3.x is old.
      
      ***
      
      License fixes (GPL -> LGPL). And typo in comments.
      Addresses merov's comments on the review board.
      
      ***
      
      Added Merov's compile fixes for windows.
      ef490e30
  27. Dec 14, 2010
    • Nat Goodspeed's avatar
      SWAT-352: when loading lleventhost, call apr_dso_error() function. · e04f9ef1
      Nat Goodspeed authored
      In addition to its usual apr_sterror() function, APR defines a special
      function specifically for errors relating to the apr_dso_*() functions.
      Introduce ll_apr_warn_status() and ll_apr_assert_status() overloads accepting
      apr_dso_handle_t* to call apr_dso_error() as well as apr_strerror() and log
      its output. Use new ll_apr_warn_status() in LLAppViewer::loadEventHostModule()
      for apr_dso_load() and apr_dso_sym() calls. Instead of shorthand
      ll_apr_assert_status(), use with llassert_always() so check is still performed
      even in Release build.
      Add more lleventhost-related debugging output, e.g. full pathname of the DLL.
      On Mac and Linux, call 'file' command to report nature of the DLL too.
      e04f9ef1
  28. Oct 13, 2010
  29. Sep 21, 2010
  30. Aug 13, 2010
  31. Apr 15, 2010
  32. Nov 13, 2009
  33. Nov 06, 2009
  34. Jul 30, 2009
  35. Jul 01, 2009
  36. May 22, 2009
Loading