summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorGravatar aeb 2000-03-16 22:22:05 +0000
committerGravatar aeb 2000-03-16 22:22:05 +0000
commitbd7a5606d22c5d0a30d4dc692f60112053c5453e (patch)
tree9ab65fb7fbc4e4ba90f9e5ddf366b6344ecd2e2f /src
parentUse correct typedef in my_tag_handler(). (diff)
Added FCP monitoring test.
git-svn-id: svn://svn.linux1394.org/libraw1394/trunk@15 53a565d1-3bb7-0310-b661-cf11e63c67ab
Diffstat (limited to 'src')
-rw-r--r--src/fcp.c8
-rw-r--r--src/testlibraw.c45
2 files changed, 46 insertions, 7 deletions
diff --git a/src/fcp.c b/src/fcp.c
index e3c0800..2c56027 100644
--- a/src/fcp.c
+++ b/src/fcp.c
@@ -6,7 +6,7 @@
#include "kernel-raw1394.h"
#include "raw1394_private.h"
-static int do_fcp_listen(struct raw1394_handle *handle)
+static int do_fcp_listen(struct raw1394_handle *handle, int startstop)
{
struct sync_cb_data sd = { 0, 0 };
struct raw1394_reqhandle rh = { (req_callback_t)_raw1394_sync_cb, &sd };
@@ -16,7 +16,7 @@ static int do_fcp_listen(struct raw1394_handle *handle)
CLEAR_REQ(req);
req->type = RAW1394_REQ_FCP_LISTEN;
req->generation = handle->generation;
- req->misc = 0;
+ req->misc = startstop;
req->tag = (unsigned long)&rh;
req->recvb = handle->buffer;
req->length = 512;
@@ -44,10 +44,10 @@ static int do_fcp_listen(struct raw1394_handle *handle)
int raw1394_start_fcp_listen(struct raw1394_handle *handle)
{
- return do_fcp_listen(handle);
+ return do_fcp_listen(handle, 1);
}
int raw1394_stop_fcp_listen(struct raw1394_handle *handle)
{
- return do_fcp_listen(handle);
+ return do_fcp_listen(handle, 0);
}
diff --git a/src/testlibraw.c b/src/testlibraw.c
index f1128dd..e18db62 100644
--- a/src/testlibraw.c
+++ b/src/testlibraw.c
@@ -1,6 +1,7 @@
#include <stdio.h>
#include <errno.h>
+#include <sys/poll.h>
#include "raw1394.h"
#include "csr.h"
@@ -17,13 +18,12 @@ const char not_loaded[] = "\
This probably means that you don't have raw1394 support in the kernel or that
you haven't loaded the raw1394 module.\n";
-
quadlet_t buffer;
int my_tag_handler(raw1394handle_t handle, unsigned long tag, int error)
{
if (error < 0) {
- printf("completed with error %d\n", error);
+ printf("failed with error %d\n", error);
} else {
printf("completed with 0x%08x, value 0x%08x\n", error, buffer);
}
@@ -31,6 +31,20 @@ int my_tag_handler(raw1394handle_t handle, unsigned long tag, int error)
return 0;
}
+int my_fcp_handler(raw1394handle_t handle, nodeid_t nodeid, int response,
+ size_t length, unsigned char *data)
+{
+ printf("got fcp %s from node %d of %d bytes:",
+ (response ? "response" : "command"), nodeid & 0x3f, length);
+
+ while (length) {
+ printf(" %02x", *data);
+ data++;
+ length--;
+ }
+
+ printf("\n");
+}
int main(int argc, char **argv)
@@ -41,7 +55,9 @@ int main(int argc, char **argv)
tag_handler_t std_handler;
int retval;
-
+
+ struct pollfd pfd;
+ unsigned char fcp_test[] = { 0x1, 0x23, 0x45, 0x67, 0x89, 0xab, 0xcd, 0xef };
handle = raw1394_get_handle();
@@ -115,5 +131,28 @@ int main(int argc, char **argv)
}
}
+ printf("\ntesting FCP monitoring on local node\n");
+ raw1394_set_fcp_handler(handle, my_fcp_handler);
+ raw1394_start_fcp_listen(handle);
+ retval = raw1394_write(handle, raw1394_get_local_id(handle),
+ CSR_REGISTER_BASE + CSR_FCP_COMMAND, sizeof(fcp_test),
+ (quadlet_t *)fcp_test);
+ retval = raw1394_write(handle, raw1394_get_local_id(handle),
+ CSR_REGISTER_BASE + CSR_FCP_RESPONSE, sizeof(fcp_test),
+ (quadlet_t *)fcp_test);
+
+ printf("\npolling for leftover messages\n");
+ pfd.fd = raw1394_get_fd(handle);
+ pfd.events = POLLIN;
+ pfd.revents = 0;
+ while (1) {
+ if (poll(&pfd, 1, 10) < 1) break;
+ raw1394_loop_iterate(handle);
+ }
+
+ if (retval < 0) {
+ perror("poll failed");
+ }
+
exit(0);
}
;follow=1'>Ok, 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