summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Stefan Richter 2009-05-30 14:11:27 +0200
committerGravatar Stefan Richter 2009-05-30 14:11:27 +0200
commitcaf94aaeab5215a3f54444fc52c57f2936facdaf (patch)
treec2b9362decc2a4bb69f2f8688c1824dd27e94aa4
parentUse new async stream ioctl (diff)
Fix memory leaks with async requests on firewire-core
Each request allocated a struct request_closure which was never freed. Signed-off-by: Stefan Richter <stefanr@s5r6.in-berlin.de>
-rw-r--r--src/fw.c13
1 files changed, 10 insertions, 3 deletions
diff --git a/src/fw.c b/src/fw.c
index 4df9ca4..fc4908e 100644
--- a/src/fw.c
+++ b/src/fw.c
@@ -249,6 +249,7 @@ handle_device_event(raw1394handle_t handle,
struct device *device = (struct device *) ec;
struct address_closure *ac;
struct request_closure *rc;
+ unsigned long tag;
raw1394_errcode_t errcode;
int len, phy_id;
int i;
@@ -287,8 +288,10 @@ handle_device_event(raw1394handle_t handle,
memcpy(rc->data, u->response.data, rc->length);
errcode = fw_to_raw1394_errcode(u->response.rcode);
+ tag = rc->tag;
+ free(rc);
- return fwhandle->tag_handler(handle, rc->tag, errcode);
+ return fwhandle->tag_handler(handle, tag, errcode);
case FW_CDEV_EVENT_REQUEST:
ac = u64_to_ptr(u->request.closure);
@@ -944,7 +947,7 @@ send_request(fw_handle_t handle, int tcode,
struct fw_cdev_send_request *request;
struct request_closure *closure;
int ioctl_nr = FW_CDEV_IOC_SEND_REQUEST;
- int fd, i;
+ int fd, i, retval;
#ifdef FW_CDEV_IOC_SEND_STREAM_PACKET /* added in kernel 2.6.30 */
if (tcode == TCODE_STREAM_DATA) {
@@ -1024,7 +1027,11 @@ node_id_ok:
}
#endif
- return ioctl(fd, ioctl_nr, request);
+ retval = ioctl(fd, ioctl_nr, request);
+ if (retval < 0)
+ free(closure);
+
+ return retval;
}
int
td>-2/+2 2003-07-22Patch from Stephen Tiedemann to allow reentrancy in raw1394's usage ofGravatar bencollins 7-200/+199 2003-07-17Patch from Dan Maas to add raw1394_iso_recv_flush() call to API, using theGravatar bencollins 2-3/+25 2003-07-17pkg-config support from Kristian Hogsberg.Gravatar bencollins 3-1/+15 2003-07-17Remove trailing whitespace, which automake chokes on.Gravatar bencollins 1-1/+1 2003-07-13Fixed section for -dev package.Gravatar bencollins 1-1/+1 2003-07-13Re-add the pdf buildGravatar bencollins 1-0/+1 2003-07-13Update Debian files.Gravatar bencollins 4-25/+73 2003-07-13Ok, the Debian package was way out of sync with upstreamGravatar bencollins 1-1/+1 2003-07-13Ooops...libtool works a bit different than I thought, but atleast it worksGravatar bencollins 2-6/+1 2003-07-13Generate and install the pdf in the Debian package.Gravatar bencollins 3-3/+4 2003-07-13Don't run configure at the end of autogen.sh. Also, remove autom4te.cache.Gravatar bencollins 1-1/+1 2003-07-13Update Debian maintainerGravatar bencollins 1-1/+2 2003-07-13Update Debian changelog.Gravatar bencollins 1-0/+8 2003-07-13File doesn't really seem needed. The NEWS file gives a good overview, andGravatar bencollins 1-4/+0 2003-07-13Fix compiler warnings.Gravatar bencollins 4-12/+22 2003-07-13Updates from 0.10.0 release.Gravatar bencollins 4-5/+14 2003-04-23add libtoolize to bootstrapGravatar ddennedy 1-1/+10 2003-04-21added Dan Maas' rawiso docsGravatar ddennedy 1-32/+295 2003-04-07new_handle_on_port() error path fix from Jim RadfordGravatar dmaas 1-1/+3 2003-03-26add raw1394_new_handle_on_port() convenience functionGravatar dmaas 2-1/+41 2003-02-22Updates for new rawiso ioctl interface.Gravatar bencollins 3-37/+125 2003-01-15add iso_xmit_sync() and iso_xmit_write(); clean up iso handling a bitGravatar dmaas 5-39/+161 2003-01-15implement tag matching for rawiso receptionGravatar dmaas 3-4/+12 2003-01-06back out previous commit - don't drop the legacy API just yetGravatar dmaas 6-173/+130 2003-01-05emulate legacy ISO reception API on top of new rawiso APIGravatar dmaas 7-131/+174 2002-12-24update iso API for multi-channel reception and new packet buffer layoutGravatar dmaas 4-123/+236 2002-12-20oops, irq_interval needs to be signedGravatar anonymous 1-1/+1 2002-12-20dmaas - renamed exported arm definitions into the raw1394_ namespace; brought...Gravatar anonymous 3-124/+48 2002-12-16rawiso updates:Gravatar dmaas 3-18/+25 2002-11-18fix cplusplus extern C blockGravatar ddennedy 1-4/+4 2002-11-18merged rawiso branchGravatar ddennedy 7-6/+488