diff options
| author | Havoc Pennington <hp@redhat.com> | 2007-07-18 21:43:23 +0000 | 
|---|---|---|
| committer | Havoc Pennington <hp@redhat.com> | 2007-07-18 21:43:23 +0000 | 
| commit | 8d939deebdce20d5609446c8839de8b3a20e5247 (patch) | |
| tree | feeec3a01c87de9d246cb383cdf33ce098e15680 | |
| parent | d012387afef0ba02185ebe27bc6bb15551912e92 (diff) | |
2007-07-18  Havoc Pennington  <hp@redhat.com>
	* dbus/dbus-message.c (dbus_message_get_cached)
	(dbus_message_cache_or_finalize): don't mess with message from
	message cache outside of the cache lock. Bug #9164 from Jonathan
	Matthew.
| -rw-r--r-- | ChangeLog | 7 | ||||
| -rw-r--r-- | dbus/dbus-message.c | 8 | 
2 files changed, 11 insertions, 4 deletions
@@ -1,3 +1,10 @@ +2007-07-18  Havoc Pennington  <hp@redhat.com> + +	* dbus/dbus-message.c (dbus_message_get_cached) +	(dbus_message_cache_or_finalize): don't mess with message from +	message cache outside of the cache lock. Bug #9164 from Jonathan +	Matthew. +  2007-07-13  Havoc Pennington  <hp@redhat.com>  	* Add indent-tabs-mode: nil to all file headers. diff --git a/dbus/dbus-message.c b/dbus/dbus-message.c index 1c92af26..91f6ebec 100644 --- a/dbus/dbus-message.c +++ b/dbus/dbus-message.c @@ -482,10 +482,10 @@ dbus_message_get_cached (void)    _dbus_assert (i < MAX_MESSAGE_CACHE_SIZE);    _dbus_assert (message != NULL); -  _DBUS_UNLOCK (message_cache); -    _dbus_assert (message->refcount.value == 0);    _dbus_assert (message->size_counters == NULL); +   +  _DBUS_UNLOCK (message_cache);    return message;  } @@ -571,10 +571,10 @@ dbus_message_cache_or_finalize (DBusMessage *message)  #endif   out: -  _DBUS_UNLOCK (message_cache); -    _dbus_assert (message->refcount.value == 0); +  _DBUS_UNLOCK (message_cache); +      if (!was_cached)      dbus_message_finalize (message);  }  | 
