aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorStefan Richter <stefanr@s5r6.in-berlin.de>2010-06-20 16:52:55 -0400
committerStefan Richter <stefanr@s5r6.in-berlin.de>2010-06-20 17:11:56 -0400
commit604f45167824e18ad5766e51ecf1d4d65f15118d (patch)
tree40deeca88e1788e98d54d82f429a45ce276c4135 /drivers
parent0244f57302f7e8bebd2f1ab58767eac2e9f678a6 (diff)
firewire: cdev: freeze FW_CDEV_VERSION due to libraw1394 bug
libraw1394 v2.0.0...v2.0.5 takes FW_CDEV_VERSION from an externally installed header file and uses it to declare its own implementation level in FW_CDEV_IOC_GET_INFO. This is wrong; it should set the real version for which it was actually written. If we add features to the kernel ABI that require the kernel to check a client's implementation level, we can not trust the client version if it was set from FW_CDEV_VERSION. Hence freeze FW_CDEV_VERSION at the current value (no damage has been done yet), clearly document FW_CDEV_VERSION as a dummy version and what clients are expected to do with fw_cdev_get_info.version, and use a new defined constant (which is not placed into the exported header file) as kernel implementation level. Note, in order to check in client program source code which features are present in an externally installed linux/firewire-cdev.h, use preprocessor directives like #ifdef FW_CDEV_IOC_ALLOCATE_ISO_RESOURCE or #ifdef FW_CDEV_EVENT_ISO_RESOURCE_ALLOCATED instead of a check of FW_CDEV_VERSION. Signed-off-by: Stefan Richter <stefanr@s5r6.in-berlin.de>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/firewire/core-cdev.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/drivers/firewire/core-cdev.c b/drivers/firewire/core-cdev.c
index 8f8c8eeaf046..0cf86bcbeea2 100644
--- a/drivers/firewire/core-cdev.c
+++ b/drivers/firewire/core-cdev.c
@@ -46,6 +46,11 @@
46 46
47#include "core.h" 47#include "core.h"
48 48
49/*
50 * ABI version history is documented in linux/firewire-cdev.h.
51 */
52#define FW_CDEV_KERNEL_VERSION 3
53
49struct client { 54struct client {
50 u32 version; 55 u32 version;
51 struct fw_device *device; 56 struct fw_device *device;
@@ -395,7 +400,7 @@ static int ioctl_get_info(struct client *client, union ioctl_arg *arg)
395 unsigned long ret = 0; 400 unsigned long ret = 0;
396 401
397 client->version = a->version; 402 client->version = a->version;
398 a->version = FW_CDEV_VERSION; 403 a->version = FW_CDEV_KERNEL_VERSION;
399 a->card = client->device->card->index; 404 a->card = client->device->card->index;
400 405
401 down_read(&fw_device_rwsem); 406 down_read(&fw_device_rwsem);