summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorGravatar Stefan Richter 2013-08-24 12:50:58 +0200
committerGravatar Stefan Richter 2013-08-24 13:07:37 +0200
commitd80678dc5545df8c5b36a265eb73f8c40ca54b5d (patch)
tree33961c8adfbb75bcd4e36b279d3d86f67021e7fe /src
parenttools: Fix startup of dumpiso and sendiso on juju (diff)
Save and restore errno in raw1394_new_handle{,_on_port} for legacy applications
Since dual-stack capability was added to libraw1394, raw1394_new_handle() and raw1394_new_handle_on_port() began to alter errno even when succeeding. This breaks old application code which contains the bug of checking for failure in errno rather than in the return code of said functions, or similar bugs with wrong assumptions about errno. While those applications should be fixed, it may not always be possible or feasible to do so. Hence add a workaround to libraw1394 which saves and restores errno in said two functions. From a superficial review of dispatch.c, it seems that these two functions are the only ones where such a workaround may be needed. However, this may not be true if any fw_XYZ() function implementation differs from the counterpart ieee1394_XYZ() function in the way that the former alters errno during successful execution while the latter does not. To be clear, altering errno in absence of failure is absolutely allowed in library code (except for signal handlers), yet it may be unexpected and be perceived as a library or kernel regression if the application client code is buggy in this regard. Reported-by: Vladimir Romanov <blueboar2@gmail.com> Signed-off-by: Stefan Richter <stefanr@s5r6.in-berlin.de>
Diffstat (limited to 'src')
-rw-r--r--src/dispatch.c10
1 files changed, 10 insertions, 0 deletions
diff --git a/src/dispatch.c b/src/dispatch.c
index 10d1939..0edfd6d 100644
--- a/src/dispatch.c
+++ b/src/dispatch.c
@@ -28,11 +28,14 @@ raw1394handle_t raw1394_new_handle(void)
fw_handle_t fw_handle;
raw1394handle_t handle;
struct raw1394_portinfo port;
+ int errno_bak;
handle = (raw1394handle_t) malloc(sizeof(struct raw1394_handle));
if (!handle)
return NULL;
+ errno_bak = errno; /* workaround for faulty legacy applications */
+
ieee1394_handle = ieee1394_new_handle();
if (!ieee1394_handle)
goto try_fw;
@@ -44,6 +47,8 @@ raw1394handle_t raw1394_new_handle(void)
}
ieee1394_destroy_handle(ieee1394_handle);
try_fw:
+ errno = errno_bak;
+
fw_handle = fw_new_handle();
if (fw_handle) {
handle->is_fw = 1;
@@ -72,11 +77,14 @@ raw1394handle_t raw1394_new_handle_on_port(int port)
ieee1394handle_t ieee1394_handle;
fw_handle_t fw_handle;
raw1394handle_t handle;
+ int errno_bak;
handle = (raw1394handle_t) malloc(sizeof(struct raw1394_handle));
if (!handle)
return NULL;
+ errno_bak = errno; /* workaround for faulty legacy applications */
+
ieee1394_handle = ieee1394_new_handle_on_port(port);
if (ieee1394_handle) {
handle->is_fw = 0;
@@ -84,6 +92,8 @@ raw1394handle_t raw1394_new_handle_on_port(int port)
return handle;
}
+ errno = errno_bak;
+
fw_handle = fw_new_handle_on_port(port);
if (fw_handle) {
handle->is_fw = 1;
eeded. 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