mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-07 22:42:04 +00:00
3dc5ea9b31
This implements the simultaneous read of the isochronous cycle timer and the system clock (in usecs). This allows to express the exact receive time of an ISO packet as a system time with microsecond accuracy. http://bugzilla.kernel.org/show_bug.cgi?id=7773 The counterpart patch for libraw1394 can be found at http://thread.gmane.org/gmane.linux.kernel.firewire.devel/8934 Patch update (Stefan R.): Disable preemption and local interrupts. Prevent integer overflow. Add paranoid error checks and kerneldoc to hpsb_read_cycle_timer. Move it to other ieee1394_core high-level API functions. Change comments. Adjust whitespace. Rename struct _raw1394_cycle_timer. Signed-off-by: Stefan Richter <stefanr@s5r6.in-berlin.de> Acked-by: Pieter Palmers <pieterp@joow.be> Acked-by: Dan Dennedy <dan@dennedy.org>
192 lines
5.0 KiB
C
192 lines
5.0 KiB
C
#ifndef IEEE1394_RAW1394_H
|
|
#define IEEE1394_RAW1394_H
|
|
|
|
/* header for the raw1394 API that is exported to user-space */
|
|
|
|
#define RAW1394_KERNELAPI_VERSION 4
|
|
|
|
/* state: opened */
|
|
#define RAW1394_REQ_INITIALIZE 1
|
|
|
|
/* state: initialized */
|
|
#define RAW1394_REQ_LIST_CARDS 2
|
|
#define RAW1394_REQ_SET_CARD 3
|
|
|
|
/* state: connected */
|
|
#define RAW1394_REQ_ASYNC_READ 100
|
|
#define RAW1394_REQ_ASYNC_WRITE 101
|
|
#define RAW1394_REQ_LOCK 102
|
|
#define RAW1394_REQ_LOCK64 103
|
|
#define RAW1394_REQ_ISO_SEND 104
|
|
#define RAW1394_REQ_ASYNC_SEND 105
|
|
#define RAW1394_REQ_ASYNC_STREAM 106
|
|
|
|
#define RAW1394_REQ_ISO_LISTEN 200
|
|
#define RAW1394_REQ_FCP_LISTEN 201
|
|
#define RAW1394_REQ_RESET_BUS 202
|
|
#define RAW1394_REQ_GET_ROM 203
|
|
#define RAW1394_REQ_UPDATE_ROM 204
|
|
#define RAW1394_REQ_ECHO 205
|
|
#define RAW1394_REQ_MODIFY_ROM 206
|
|
|
|
#define RAW1394_REQ_ARM_REGISTER 300
|
|
#define RAW1394_REQ_ARM_UNREGISTER 301
|
|
#define RAW1394_REQ_ARM_SET_BUF 302
|
|
#define RAW1394_REQ_ARM_GET_BUF 303
|
|
|
|
#define RAW1394_REQ_RESET_NOTIFY 400
|
|
|
|
#define RAW1394_REQ_PHYPACKET 500
|
|
|
|
/* kernel to user */
|
|
#define RAW1394_REQ_BUS_RESET 10000
|
|
#define RAW1394_REQ_ISO_RECEIVE 10001
|
|
#define RAW1394_REQ_FCP_REQUEST 10002
|
|
#define RAW1394_REQ_ARM 10003
|
|
#define RAW1394_REQ_RAWISO_ACTIVITY 10004
|
|
|
|
/* error codes */
|
|
#define RAW1394_ERROR_NONE 0
|
|
#define RAW1394_ERROR_COMPAT (-1001)
|
|
#define RAW1394_ERROR_STATE_ORDER (-1002)
|
|
#define RAW1394_ERROR_GENERATION (-1003)
|
|
#define RAW1394_ERROR_INVALID_ARG (-1004)
|
|
#define RAW1394_ERROR_MEMFAULT (-1005)
|
|
#define RAW1394_ERROR_ALREADY (-1006)
|
|
|
|
#define RAW1394_ERROR_EXCESSIVE (-1020)
|
|
#define RAW1394_ERROR_UNTIDY_LEN (-1021)
|
|
|
|
#define RAW1394_ERROR_SEND_ERROR (-1100)
|
|
#define RAW1394_ERROR_ABORTED (-1101)
|
|
#define RAW1394_ERROR_TIMEOUT (-1102)
|
|
|
|
/* arm_codes */
|
|
#define ARM_READ 1
|
|
#define ARM_WRITE 2
|
|
#define ARM_LOCK 4
|
|
|
|
#define RAW1394_LONG_RESET 0
|
|
#define RAW1394_SHORT_RESET 1
|
|
|
|
/* busresetnotify ... */
|
|
#define RAW1394_NOTIFY_OFF 0
|
|
#define RAW1394_NOTIFY_ON 1
|
|
|
|
#include <asm/types.h>
|
|
|
|
struct raw1394_request {
|
|
__u32 type;
|
|
__s32 error;
|
|
__u32 misc;
|
|
|
|
__u32 generation;
|
|
__u32 length;
|
|
|
|
__u64 address;
|
|
|
|
__u64 tag;
|
|
|
|
__u64 sendb;
|
|
__u64 recvb;
|
|
};
|
|
|
|
struct raw1394_khost_list {
|
|
__u32 nodes;
|
|
__u8 name[32];
|
|
};
|
|
|
|
typedef struct arm_request {
|
|
__u16 destination_nodeid;
|
|
__u16 source_nodeid;
|
|
__u64 destination_offset;
|
|
__u8 tlabel;
|
|
__u8 tcode;
|
|
__u8 extended_transaction_code;
|
|
__u32 generation;
|
|
__u16 buffer_length;
|
|
__u8 __user *buffer;
|
|
} *arm_request_t;
|
|
|
|
typedef struct arm_response {
|
|
__s32 response_code;
|
|
__u16 buffer_length;
|
|
__u8 __user *buffer;
|
|
} *arm_response_t;
|
|
|
|
typedef struct arm_request_response {
|
|
struct arm_request __user *request;
|
|
struct arm_response __user *response;
|
|
} *arm_request_response_t;
|
|
|
|
/* rawiso API */
|
|
#include "ieee1394-ioctl.h"
|
|
|
|
/* per-packet metadata embedded in the ringbuffer */
|
|
/* must be identical to hpsb_iso_packet_info in iso.h! */
|
|
struct raw1394_iso_packet_info {
|
|
__u32 offset;
|
|
__u16 len;
|
|
__u16 cycle; /* recv only */
|
|
__u8 channel; /* recv only */
|
|
__u8 tag;
|
|
__u8 sy;
|
|
};
|
|
|
|
/* argument for RAW1394_ISO_RECV/XMIT_PACKETS ioctls */
|
|
struct raw1394_iso_packets {
|
|
__u32 n_packets;
|
|
struct raw1394_iso_packet_info __user *infos;
|
|
};
|
|
|
|
struct raw1394_iso_config {
|
|
/* size of packet data buffer, in bytes (will be rounded up to PAGE_SIZE) */
|
|
__u32 data_buf_size;
|
|
|
|
/* # of packets to buffer */
|
|
__u32 buf_packets;
|
|
|
|
/* iso channel (set to -1 for multi-channel recv) */
|
|
__s32 channel;
|
|
|
|
/* xmit only - iso transmission speed */
|
|
__u8 speed;
|
|
|
|
/* The mode of the dma when receiving iso data. Must be supported by chip */
|
|
__u8 dma_mode;
|
|
|
|
/* max. latency of buffer, in packets (-1 if you don't care) */
|
|
__s32 irq_interval;
|
|
};
|
|
|
|
/* argument to RAW1394_ISO_XMIT/RECV_INIT and RAW1394_ISO_GET_STATUS */
|
|
struct raw1394_iso_status {
|
|
/* current settings */
|
|
struct raw1394_iso_config config;
|
|
|
|
/* number of packets waiting to be filled with data (ISO transmission)
|
|
or containing data received (ISO reception) */
|
|
__u32 n_packets;
|
|
|
|
/* approximate number of packets dropped due to overflow or
|
|
underflow of the packet buffer (a value of zero guarantees
|
|
that no packets have been dropped) */
|
|
__u32 overflows;
|
|
|
|
/* cycle number at which next packet will be transmitted;
|
|
-1 if not known */
|
|
__s16 xmit_cycle;
|
|
};
|
|
|
|
/* argument to RAW1394_IOC_GET_CYCLE_TIMER ioctl */
|
|
struct raw1394_cycle_timer {
|
|
/* contents of Isochronous Cycle Timer register,
|
|
as in OHCI 1.1 clause 5.13 (also with non-OHCI hosts) */
|
|
__u32 cycle_timer;
|
|
|
|
/* local time in microseconds since Epoch,
|
|
simultaneously read with cycle timer */
|
|
__u64 local_time;
|
|
};
|
|
#endif /* IEEE1394_RAW1394_H */
|