summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorGravatar Stefan Richter 2009-05-30 13:18:59 +0200
committerGravatar Stefan Richter 2009-05-30 13:18:59 +0200
commitefb814334e7c70cef7c8077f7edbc6b9980a88c7 (patch)
tree25fb7ab3e07cb5bdd9cfa52b407a6ab1ea87fd7c /src
parentIso reception: Use packet timestamps in juju ABI v2 (diff)
Use new async stream ioctl
This implements asynchronous streams on juju, i.e. enables raw1394_async_stream() and raw1394_start_async_stream() to work with the new firewire kernel stack. Signed-off-by: Stefan Richter <stefanr@s5r6.in-berlin.de>
Diffstat (limited to '')
-rw-r--r--src/dispatch.c2
-rw-r--r--src/fw.c64
-rw-r--r--src/fw.h2
3 files changed, 52 insertions, 16 deletions
diff --git a/src/dispatch.c b/src/dispatch.c
index d202424..17eb28d 100644
--- a/src/dispatch.c
+++ b/src/dispatch.c
@@ -459,7 +459,7 @@ int raw1394_async_stream(raw1394handle_t handle, unsigned int channel,
return -1;
}
if (handle->is_fw)
- return fw_async_stream(handle->mode.fw, channel, tag, sy, speed, length, data);
+ return fw_async_stream(handle, channel, tag, sy, speed, length, data);
else
return ieee1394_async_stream(handle, channel, tag, sy, speed, length, data);
}
diff --git a/src/fw.c b/src/fw.c
index ae09fed..4df9ca4 100644
--- a/src/fw.c
+++ b/src/fw.c
@@ -946,6 +946,18 @@ send_request(fw_handle_t handle, int tcode,
int ioctl_nr = FW_CDEV_IOC_SEND_REQUEST;
int fd, i;
+#ifdef FW_CDEV_IOC_SEND_STREAM_PACKET /* added in kernel 2.6.30 */
+ if (tcode == TCODE_STREAM_DATA) {
+ ioctl_nr = FW_CDEV_IOC_SEND_STREAM_PACKET;
+ fd = handle->ioctl_fd;
+ }
+#else
+ if (tcode == TCODE_STREAM_DATA) {
+ errno = ENOSYS;
+ return -1;
+ }
+#endif
+
#ifdef FW_CDEV_IOC_SEND_BROADCAST_REQUEST /* added in kernel 2.6.30 */
if (node == 0xffff) {
ioctl_nr = FW_CDEV_IOC_SEND_BROADCAST_REQUEST;
@@ -984,17 +996,33 @@ node_id_ok:
return -1;
}
- closure->data = out;
+ closure->data = out;
closure->length = out_length;
- closure->tag = tag;
+ closure->tag = tag;
request = (struct fw_cdev_send_request *) handle->buffer;
- request->tcode = tcode;
+ request->tcode = tcode;
+ request->length = in_length > out_length ? in_length : out_length;
+ request->offset = addr;
+ request->closure = ptr_to_u64(closure);
+ request->data = ptr_to_u64(in);
request->generation = handle->generation;
- request->offset = addr;
- request->length = in_length > out_length ? in_length : out_length;
- request->closure = ptr_to_u64(closure);
- request->data = ptr_to_u64(in);
+
+#ifdef FW_CDEV_IOC_SEND_STREAM_PACKET
+ if (tcode == TCODE_STREAM_DATA) {
+ struct fw_cdev_send_stream_packet *p
+ = (struct fw_cdev_send_stream_packet *) request;
+
+ p->length = in_length;
+ p->tag = (addr >> 14) & 0x3;
+ p->channel = (addr >> 8) & 0x3f;
+ p->sy = addr & 0xf;
+ p->closure = ptr_to_u64(closure);
+ p->data = ptr_to_u64(in);
+ p->generation = handle->generation;
+ p->speed = (addr >> 4) & 0x7;
+ }
+#endif
return ioctl(fd, ioctl_nr, request);
}
@@ -1115,9 +1143,13 @@ fw_start_async_stream(fw_handle_t handle, unsigned int channel,
unsigned int speed, size_t length, quadlet_t *data,
unsigned long rawtag)
{
- /* FIXME: implement this? */
- errno = ENOSYS;
- return -1;
+ nodeaddr_t addr = (tag & 0x3) << 14 |
+ (channel & 0x3f) << 8 |
+ (speed & 0x7) << 4 |
+ (sy & 0xf);
+
+ return send_request(handle, TCODE_STREAM_DATA,
+ 0, addr, length, data, 0, NULL, rawtag);
}
@@ -1242,13 +1274,17 @@ fw_lock64(raw1394handle_t handle, nodeid_t node, nodeaddr_t addr,
}
int
-fw_async_stream(fw_handle_t handle, unsigned int channel,
+fw_async_stream(raw1394handle_t handle, unsigned int channel,
unsigned int tag, unsigned int sy, unsigned int speed,
size_t length, quadlet_t *data)
{
- /* FIXME: implement this? */
- errno = ENOSYS;
- return -1;
+ nodeaddr_t addr = (tag & 0x3) << 14 |
+ (channel & 0x3f) << 8 |
+ (speed & 0x7) << 4 |
+ (sy & 0xf);
+
+ return send_request_sync(handle, TCODE_STREAM_DATA,
+ 0, addr, length, data, 0, NULL);
}
int
diff --git a/src/fw.h b/src/fw.h
index ffd2c05..04e2b06 100644
--- a/src/fw.h
+++ b/src/fw.h
@@ -189,7 +189,7 @@ int fw_lock(raw1394handle_t handle, nodeid_t node, nodeaddr_t addr,
int fw_lock64(raw1394handle_t handle, nodeid_t node, nodeaddr_t addr,
unsigned int extcode, octlet_t data, octlet_t arg,
octlet_t *result);
-int fw_async_stream(fw_handle_t handle, unsigned int channel,
+int fw_async_stream(raw1394handle_t handle, unsigned int channel,
unsigned int tag, unsigned int sy, unsigned int speed,
size_t length, quadlet_t *data);
int fw_async_send(fw_handle_t handle,
avatar/2fce9f8dd90949315d789a6546dfacd0?s=13&d=retro' width='13' height='13' alt='Gravatar' /> bencollins 1-1/+1 git-svn-id: svn://svn.linux1394.org/libraw1394/trunk@119 53a565d1-3bb7-0310-b661-cf11e63c67ab 2003-07-13Ooops...libtool works a bit different than I thought, but atleast it worksGravatar bencollins 2-6/+1 like it is supposed to. git-svn-id: svn://svn.linux1394.org/libraw1394/trunk@117 53a565d1-3bb7-0310-b661-cf11e63c67ab 2003-07-13Generate and install the pdf in the Debian package.Gravatar bencollins 3-3/+4 git-svn-id: svn://svn.linux1394.org/libraw1394/trunk@114 53a565d1-3bb7-0310-b661-cf11e63c67ab 2003-07-13Don't run configure at the end of autogen.sh. Also, remove autom4te.cache.Gravatar bencollins 1-1/+1 git-svn-id: svn://svn.linux1394.org/libraw1394/trunk@113 53a565d1-3bb7-0310-b661-cf11e63c67ab 2003-07-13Update Debian maintainerGravatar bencollins 1-1/+2 git-svn-id: svn://svn.linux1394.org/libraw1394/trunk@112 53a565d1-3bb7-0310-b661-cf11e63c67ab 2003-07-13Update Debian changelog.Gravatar bencollins 1-0/+8 git-svn-id: svn://svn.linux1394.org/libraw1394/trunk@111 53a565d1-3bb7-0310-b661-cf11e63c67ab 2003-07-13File doesn't really seem needed. The NEWS file gives a good overview, andGravatar bencollins 1-4/+0 the svn log is more than verbose enough for info seekers. git-svn-id: svn://svn.linux1394.org/libraw1394/trunk@110 53a565d1-3bb7-0310-b661-cf11e63c67ab 2003-07-13Fix compiler warnings.Gravatar bencollins 4-12/+22 git-svn-id: svn://svn.linux1394.org/libraw1394/trunk@109 53a565d1-3bb7-0310-b661-cf11e63c67ab 2003-07-13Updates from 0.10.0 release.Gravatar bencollins 4-5/+14 git-svn-id: svn://svn.linux1394.org/libraw1394/trunk@108 53a565d1-3bb7-0310-b661-cf11e63c67ab 2003-04-23add libtoolize to bootstrapGravatar ddennedy 1-1/+10 git-svn-id: svn://svn.linux1394.org/libraw1394/trunk@107 53a565d1-3bb7-0310-b661-cf11e63c67ab 2003-04-21added Dan Maas' rawiso docsGravatar ddennedy 1-32/+295 git-svn-id: svn://svn.linux1394.org/libraw1394/trunk@106 53a565d1-3bb7-0310-b661-cf11e63c67ab 2003-04-07new_handle_on_port() error path fix from Jim RadfordGravatar dmaas 1-1/+3 git-svn-id: svn://svn.linux1394.org/libraw1394/trunk@105 53a565d1-3bb7-0310-b661-cf11e63c67ab 2003-03-26add raw1394_new_handle_on_port() convenience functionGravatar dmaas 2-1/+41 git-svn-id: svn://svn.linux1394.org/libraw1394/trunk@104 53a565d1-3bb7-0310-b661-cf11e63c67ab 2003-02-22Updates for new rawiso ioctl interface.Gravatar bencollins 3-37/+125 git-svn-id: svn://svn.linux1394.org/libraw1394/trunk@103 53a565d1-3bb7-0310-b661-cf11e63c67ab 2003-01-15add iso_xmit_sync() and iso_xmit_write(); clean up iso handling a bitGravatar dmaas 5-39/+161 git-svn-id: svn://svn.linux1394.org/libraw1394/trunk@102 53a565d1-3bb7-0310-b661-cf11e63c67ab 2003-01-15implement tag matching for rawiso receptionGravatar dmaas 3-4/+12 git-svn-id: svn://svn.linux1394.org/libraw1394/trunk@101 53a565d1-3bb7-0310-b661-cf11e63c67ab 2003-01-06back out previous commit - don't drop the legacy API just yetGravatar dmaas 6-173/+130 git-svn-id: svn://svn.linux1394.org/libraw1394/trunk@100 53a565d1-3bb7-0310-b661-cf11e63c67ab 2003-01-05emulate legacy ISO reception API on top of new rawiso APIGravatar dmaas 7-131/+174 git-svn-id: svn://svn.linux1394.org/libraw1394/trunk@99 53a565d1-3bb7-0310-b661-cf11e63c67ab 2002-12-24update iso API for multi-channel reception and new packet buffer layoutGravatar dmaas 4-123/+236 git-svn-id: svn://svn.linux1394.org/libraw1394/trunk@98 53a565d1-3bb7-0310-b661-cf11e63c67ab 2002-12-20oops, irq_interval needs to be signedGravatar anonymous 1-1/+1 git-svn-id: svn://svn.linux1394.org/libraw1394/trunk@97 53a565d1-3bb7-0310-b661-cf11e63c67ab 2002-12-20dmaas - renamed exported arm definitions into the raw1394_ namespace; ↵Gravatar anonymous 3-124/+48 brought kernel-raw1394.h back in sync with the kernel version git-svn-id: svn://svn.linux1394.org/libraw1394/trunk@96 53a565d1-3bb7-0310-b661-cf11e63c67ab 2002-12-16rawiso updates:Gravatar dmaas 3-18/+25 - changed return type of rawiso xmit/recv handlers from int to enum raw1394_iso_disposition - added an ioctl (RAW1394_ISO_QUEUE_ACTIVITY) to force an ISO_ACTIVITY event into the queue. This is needed for handling RAW1394_ISO_DEFER, to kick us out of the next read() instead of sleeping forever. - removed references to "8-byte" isochronous header - this is an OHCI-specific implementation detail git-svn-id: svn://svn.linux1394.org/libraw1394/trunk@95 53a565d1-3bb7-0310-b661-cf11e63c67ab 2002-11-18fix cplusplus extern C blockGravatar ddennedy 1-4/+4 git-svn-id: svn://svn.linux1394.org/libraw1394/trunk@94 53a565d1-3bb7-0310-b661-cf11e63c67ab 2002-11-18merged rawiso branchGravatar ddennedy 7-6/+488 git-svn-id: svn://svn.linux1394.org/libraw1394/trunk@93 53a565d1-3bb7-0310-b661-cf11e63c67ab