2000-06-14 11:01:42 -04:00
|
|
|
/*
|
|
|
|
* libraw1394 - library for raw access to the 1394 bus with the Linux subsystem.
|
|
|
|
*
|
2002-10-13 18:54:49 -04:00
|
|
|
* Copyright (C) 1999,2000,2001,2002 Andreas Bombe
|
2000-06-14 11:01:42 -04:00
|
|
|
*
|
|
|
|
* This library is licensed under the GNU Lesser General Public License (LGPL),
|
|
|
|
* version 2.1 or later. See the file COPYING.LIB in the distribution for
|
|
|
|
* details.
|
|
|
|
*/
|
2000-03-15 22:40:52 -05:00
|
|
|
|
2000-05-28 17:00:56 -04:00
|
|
|
#include <config.h>
|
2000-03-15 22:40:52 -05:00
|
|
|
#include <errno.h>
|
|
|
|
#include <unistd.h>
|
2003-07-12 20:49:54 -04:00
|
|
|
#include <string.h>
|
2000-03-15 22:40:52 -05:00
|
|
|
|
|
|
|
#include "raw1394.h"
|
|
|
|
#include "kernel-raw1394.h"
|
|
|
|
#include "raw1394_private.h"
|
|
|
|
|
2000-03-16 17:22:05 -05:00
|
|
|
static int do_fcp_listen(struct raw1394_handle *handle, int startstop)
|
2000-03-15 22:40:52 -05:00
|
|
|
{
|
|
|
|
struct sync_cb_data sd = { 0, 0 };
|
|
|
|
struct raw1394_reqhandle rh = { (req_callback_t)_raw1394_sync_cb, &sd };
|
|
|
|
int err;
|
|
|
|
struct raw1394_request *req = &handle->req;
|
|
|
|
|
|
|
|
CLEAR_REQ(req);
|
|
|
|
req->type = RAW1394_REQ_FCP_LISTEN;
|
|
|
|
req->generation = handle->generation;
|
2000-03-16 17:22:05 -05:00
|
|
|
req->misc = startstop;
|
2000-09-10 18:18:49 -04:00
|
|
|
req->tag = ptr2int(&rh);
|
|
|
|
req->recvb = ptr2int(handle->buffer);
|
2000-03-15 22:40:52 -05:00
|
|
|
req->length = 512;
|
|
|
|
|
|
|
|
err = write(handle->fd, req, sizeof(*req));
|
|
|
|
while (!sd.done) {
|
|
|
|
if (err < 0) return err;
|
|
|
|
err = raw1394_loop_iterate(handle);
|
|
|
|
}
|
|
|
|
|
|
|
|
switch (sd.errcode) {
|
|
|
|
case RAW1394_ERROR_ALREADY:
|
|
|
|
errno = EALREADY;
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
case RAW1394_ERROR_INVALID_ARG:
|
|
|
|
errno = EINVAL;
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
default:
|
|
|
|
errno = 0;
|
|
|
|
return sd.errcode;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2002-10-13 18:54:49 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* raw1394_start_fcp_listen - enable reception of FCP events
|
|
|
|
*
|
|
|
|
* Enables the reception of FCP events (writes to the FCP_COMMAND or
|
|
|
|
* FCP_RESPONSE address ranges) on @handle. FCP requests are then passed to the
|
|
|
|
* callback specified with raw1394_set_fcp_handler().
|
|
|
|
**/
|
2000-03-15 22:40:52 -05:00
|
|
|
int raw1394_start_fcp_listen(struct raw1394_handle *handle)
|
|
|
|
{
|
2000-03-16 17:22:05 -05:00
|
|
|
return do_fcp_listen(handle, 1);
|
2000-03-15 22:40:52 -05:00
|
|
|
}
|
|
|
|
|
2002-10-13 18:54:49 -04:00
|
|
|
/**
|
|
|
|
* raw1394_stop_fcp_listen - disable reception of FCP events
|
|
|
|
*
|
|
|
|
* Stops the reception of FCP events (writes to the FCP_COMMAND or
|
|
|
|
* FCP_RESPONSE address ranges) on @handle.
|
|
|
|
**/
|
2000-03-15 22:40:52 -05:00
|
|
|
int raw1394_stop_fcp_listen(struct raw1394_handle *handle)
|
|
|
|
{
|
2000-03-16 17:22:05 -05:00
|
|
|
return do_fcp_listen(handle, 0);
|
2000-03-15 22:40:52 -05:00
|
|
|
}
|