Add qemu 2.4.0
[kvmfornfv.git] / qemu / roms / ipxe / src / include / ipxe / xfer.h
1 #ifndef _IPXE_XFER_H
2 #define _IPXE_XFER_H
3
4 /** @file
5  *
6  * Data transfer interfaces
7  *
8  */
9
10 FILE_LICENCE ( GPL2_OR_LATER );
11
12 #include <stddef.h>
13 #include <stdarg.h>
14 #include <ipxe/interface.h>
15
16 struct xfer_metadata;
17 struct io_buffer;
18 struct sockaddr;
19 struct net_device;
20
21 /** Data transfer metadata */
22 struct xfer_metadata {
23         /** Flags
24          *
25          * This is the bitwise OR of zero or more @c XFER_FL_XXX
26          * constants.
27          */
28         unsigned int flags;
29         /** Offset of data within stream
30          *
31          * This is an absolute offset if the @c XFER_FL_ABS_OFFSET
32          * flag is set, otherwise a relative offset.  (A freshly
33          * zeroed @c xfer_metadata structure therefore represents a
34          * relative offset of zero, i.e. no offset from the current
35          * position.)
36          */
37         off_t offset;
38         /** Source socket address, or NULL */
39         struct sockaddr *src;
40         /** Destination socket address, or NULL */
41         struct sockaddr *dest;
42         /** Network device, or NULL */
43         struct net_device *netdev;
44 };
45
46 /** Offset is absolute */
47 #define XFER_FL_ABS_OFFSET 0x0001
48
49 /** Sender is relinquishing use of half-duplex channel */
50 #define XFER_FL_OVER 0x0002
51
52 /** This is the final data transfer */
53 #define XFER_FL_OUT 0x0004
54
55 /** Data content represents a command or status message
56  *
57  * The flag @c XFER_FL_RESPONSE is used to distinguish between a
58  * command message and a status message.
59  */
60 #define XFER_FL_CMD_STAT 0x0008
61
62 /** Data content is a response */
63 #define XFER_FL_RESPONSE 0x0010
64
65 /* Data transfer interface operations */
66
67 extern int xfer_vredirect ( struct interface *intf, int type,
68                             va_list args );
69 #define xfer_vredirect_TYPE( object_type ) \
70         typeof ( int ( object_type, int type, va_list args ) )
71
72 extern size_t xfer_window ( struct interface *intf );
73 #define xfer_window_TYPE( object_type ) \
74         typeof ( size_t ( object_type ) )
75
76 extern void xfer_window_changed ( struct interface *intf );
77 #define xfer_window_changed_TYPE( object_type ) \
78         typeof ( void ( object_type ) )
79
80 extern struct io_buffer * xfer_alloc_iob ( struct interface *intf,
81                                            size_t len );
82 #define xfer_alloc_iob_TYPE( object_type ) \
83         typeof ( struct io_buffer * ( object_type, size_t len ) )
84
85 extern int xfer_deliver ( struct interface *intf,
86                           struct io_buffer *iobuf,
87                           struct xfer_metadata *meta );
88 #define xfer_deliver_TYPE( object_type )                        \
89         typeof ( int ( object_type, struct io_buffer *iobuf,    \
90                        struct xfer_metadata *meta ) )
91
92 /* Data transfer interface helper functions */
93
94 extern int xfer_redirect ( struct interface *xfer, int type, ... );
95 extern int xfer_deliver_iob ( struct interface *intf,
96                               struct io_buffer *iobuf );
97 extern int xfer_deliver_raw_meta ( struct interface *intf, const void *data,
98                                    size_t len, struct xfer_metadata *meta );
99 extern int xfer_deliver_raw ( struct interface *intf,
100                               const void *data, size_t len );
101 extern int xfer_vprintf ( struct interface *intf,
102                           const char *format, va_list args );
103 extern int __attribute__ (( format ( printf, 2, 3 ) ))
104 xfer_printf ( struct interface *intf, const char *format, ... );
105 extern int xfer_seek ( struct interface *intf, off_t offset );
106
107 #endif /* _IPXE_XFER_H */