summaryrefslogtreecommitdiffstats
path: root/src
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 /src
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>
Diffstat (limited to 'src')
-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
atar.com/avatar/4fdeb2365dc75bd544972b8cdb7992fd?s=13&d=retro' width='13' height='13' alt='Gravatar' /> aeb 1-1/+2 2001-02-05Add libraw1394 autoconf macro (not yet complete).Gravatar aeb 5-1/+183 2001-01-31Put 'extern "C"' for C++ back in.Gravatar aeb 1-1/+1 2001-01-27Adapted testlibraw to new style error handling.Gravatar aeb 1-17/+18 2001-01-19Fix building errors.c.Gravatar aeb 2-0/+2 2001-01-19First implementation of new error reporting API.Gravatar aeb 7-28/+134 2001-01-04Fix misplaced device file in Debian installation.Gravatar aeb 3-3/+10 2000-12-12Debian scripts use makedev (>=2.3.1-49) in postinst by default now.Gravatar aeb 7-30/+104 2000-11-25Fix postinst ldconfig.Gravatar aeb 2-11/+11 2000-11-25Add some information about return values.Gravatar aeb 1-3/+29 2000-11-24Bump up version numbers for release.Gravatar aeb 2-3/+11 2000-11-24Added libraw1394.postinst.in to list of distributed files.Gravatar aeb 3-3/+35 2000-11-23Add ldconfig in deb postinst for Debian policy conformance.Gravatar aeb 2-2/+17 2000-11-23Removed acconfig.h, which wasn't needed for some time.Gravatar aeb 1-13/+0 2000-11-22Added ieee1394.h header.Gravatar aeb 3-1/+38 2000-09-13Fix raw1394_start_iso_write() which uses wrong variable.Gravatar aeb 1-1/+1 2000-09-10Work around compiler warnings for int/ptr casts.Gravatar aeb 6-10/+20 2000-09-10Added control files for Debian packages.Gravatar aeb 6-8/+106 2000-09-01Added missing prototypes for iso send functions.Gravatar aeb 1-0/+7 2000-08-08Added raw1394_get_irm_id().Gravatar aeb 7-7/+39 2000-08-06Added support for isochronous sending.Gravatar aeb 3-0/+35 2000-07-05Added raw1394_reset_bus() call.Gravatar aeb 4-0/+23 2000-06-22- Set library version info in configure.in, use in src/Makefile.am.Gravatar aeb 4-2/+16 2000-06-15Update libtool version number.Gravatar aeb 2-2/+2 2000-06-14Added copyright headers.Gravatar aeb 6-0/+54 2000-06-11Added explicit AC_PROG_INSTALL call.Gravatar aeb 1-0/+1 2000-06-09Fix size of error field.Gravatar aeb 1-2/+2 2000-06-02Modified support for 32/64 bit environments, control struct fields have fixed...Gravatar aeb 7-43/+28 2000-05-28Added support for environments with 64 bit kernel and 32 bit userland.Gravatar aeb 8-7/+45 2000-04-27Fixed missing setting of ext code in raw1394_start_lock()Gravatar aeb 1-0/+1 2000-04-15Fixed lock transaction to actually return response value.Gravatar aeb 3-5/+11 2000-04-12Add userdata functions as news.Gravatar aeb 1-0/+4 2000-04-05Add userdata functions.Gravatar aeb 3-0/+18 2000-03-18Bump version number to 0.6.Gravatar aeb 3-5/+6 2000-03-18Mention byte order change.Gravatar aeb 1-0/+2 2000-03-18Mention SourceForge home.Gravatar aeb 1-1/+5