pad: don't cache the peer chainfunc

There is no need to cache the peer chainfunction as we can just as efficiently
get to it from the peer object. Also not caching the chain function works better
because then we automatically get the new chainfunctions when they change.
This commit is contained in:
Wim Taymans 2010-12-03 11:11:24 +01:00
parent d3630379da
commit 59bc71c47a

View file

@ -101,7 +101,6 @@ struct _GstPadPushCache
{ {
GstPad *peer; /* reffed peer pad */ GstPad *peer; /* reffed peer pad */
GstCaps *caps; /* caps for this link */ GstCaps *caps; /* caps for this link */
GstPadChainFunction chainfunc;
}; };
static GstPadPushCache _pad_cache_invalid = { NULL, }; static GstPadPushCache _pad_cache_invalid = { NULL, };
@ -4216,7 +4215,6 @@ gst_pad_chain_data_unchecked (GstPad * pad, gboolean is_buffer, void *data,
if (cache) { if (cache) {
cache->peer = gst_object_ref (pad); cache->peer = gst_object_ref (pad);
cache->caps = caps ? gst_caps_ref (caps) : NULL; cache->caps = caps ? gst_caps_ref (caps) : NULL;
cache->chainfunc = chainfunc;
} }
ret = chainfunc (pad, GST_BUFFER_CAST (data)); ret = chainfunc (pad, GST_BUFFER_CAST (data));
@ -4647,7 +4645,7 @@ gst_pad_push (GstPad * pad, GstBuffer * buffer)
GST_PAD_STREAM_LOCK (peer); GST_PAD_STREAM_LOCK (peer);
ret = cache->chainfunc (peer, buffer); ret = GST_PAD_CHAINFUNC (peer) (peer, buffer);
GST_PAD_STREAM_UNLOCK (peer); GST_PAD_STREAM_UNLOCK (peer);