Browse Source

Added deliver-as-iobuf/deliver-as-raw concepts.

tags/v0.9.3
Michael Brown 17 years ago
parent
commit
1c765b3988
2 changed files with 91 additions and 6 deletions
  1. 58
    5
      src/core/xfer.c
  2. 33
    1
      src/include/gpxe/xfer.h

+ 58
- 5
src/core/xfer.c View File

16
  * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
16
  * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
17
  */
17
  */
18
 
18
 
19
+#include <string.h>
19
 #include <errno.h>
20
 #include <errno.h>
20
 #include <gpxe/xfer.h>
21
 #include <gpxe/xfer.h>
21
 
22
 
39
 }
40
 }
40
 
41
 
41
 /**
42
 /**
42
- * Null deliver datagram
43
+ * Deliver datagram as raw data
43
  *
44
  *
44
  * @v xfer		Data-transfer interface
45
  * @v xfer		Data-transfer interface
45
  * @v src		Source interface
46
  * @v src		Source interface
46
  * @v iobuf		Datagram I/O buffer
47
  * @v iobuf		Datagram I/O buffer
47
  * @ret rc		Return status code
48
  * @ret rc		Return status code
49
+ *
50
+ * This function is intended to be used as the deliver() method for
51
+ * data transfer interfaces that prefer to handle raw data.
48
  */
52
  */
49
-static int null_deliver ( struct xfer_interface *xfer __unused,
50
-			  struct xfer_interface *src __unused,
51
-			  struct io_buffer *iobuf ) {
53
+int deliver_as_raw ( struct xfer_interface *xfer,
54
+		     struct xfer_interface *src,
55
+		     struct io_buffer *iobuf ) {
56
+	int rc;
57
+
58
+	rc = xfer->op->deliver_raw ( xfer, src, iobuf->data,
59
+				     iob_len ( iobuf ) );
52
 	free_iob ( iobuf );
60
 	free_iob ( iobuf );
61
+	return rc;
62
+}
63
+
64
+/**
65
+ * Deliver datagram as I/O buffer
66
+ *
67
+ * @v xfer		Data-transfer interface
68
+ * @v src		Source interface
69
+ * @v data		Data buffer
70
+ * @v len		Length of data buffer
71
+ * @ret rc		Return status code
72
+ *
73
+ * This function is intended to be used as the deliver_raw() method
74
+ * for data transfer interfaces that prefer to handle I/O buffers.
75
+ */
76
+int deliver_as_iobuf ( struct xfer_interface *xfer,
77
+		       struct xfer_interface *src,
78
+		       const void *data, size_t len ) {
79
+	struct io_buffer *iobuf;
80
+
81
+#warning "Do we need interface-specific I/O buffer allocation?"
82
+	iobuf = alloc_iob ( len );
83
+	if ( ! iobuf )
84
+		return -ENOMEM;
85
+
86
+	memcpy ( iob_put ( iobuf, len ), data, len );
87
+	return xfer->op->deliver ( xfer, src, iobuf );
88
+}
89
+
90
+/**
91
+ * Null deliver datagram as raw data
92
+ *
93
+ * @v xfer		Data-transfer interface
94
+ * @v src		Source interface
95
+ * @v data		Data buffer
96
+ * @v len		Length of data buffer
97
+ * @ret rc		Return status code
98
+ */
99
+static int null_deliver_raw ( struct xfer_interface *xfer,
100
+			      struct xfer_interface *src,
101
+			      const void *data __unused, size_t len ) {
102
+	DBGC ( src, "XFER %p->%p %zd bytes delivered %s\n", src, xfer, len,
103
+	       ( ( xfer == &null_xfer ) ?
104
+		 "before connection" : "after termination" ) );
53
 	return -EPIPE;
105
 	return -EPIPE;
54
 }
106
 }
55
 
107
 
56
 /** Null data transfer interface operations */
108
 /** Null data transfer interface operations */
57
 struct xfer_interface_operations null_xfer_ops = {
109
 struct xfer_interface_operations null_xfer_ops = {
58
-	.deliver = null_deliver,
110
+	.deliver	= deliver_as_raw,
111
+	.deliver_raw	= null_deliver_raw,
59
 };
112
 };
60
 
113
 
61
 /**
114
 /**

+ 33
- 1
src/include/gpxe/xfer.h View File

18
 	/** Deliver datagram
18
 	/** Deliver datagram
19
 	 *
19
 	 *
20
 	 * @v xfer		Data-transfer interface
20
 	 * @v xfer		Data-transfer interface
21
-	 * @v src		Source  interface
21
+	 * @v src		Source interface
22
 	 * @v iobuf		Datagram I/O buffer
22
 	 * @v iobuf		Datagram I/O buffer
23
 	 * @ret rc		Return status code
23
 	 * @ret rc		Return status code
24
+	 *
25
+	 * A data transfer interface that wishes to support only raw
26
+	 * data delivery should set this method to
27
+	 * deliver_as_raw().
24
 	 */
28
 	 */
25
 	int ( * deliver ) ( struct xfer_interface *xfer,
29
 	int ( * deliver ) ( struct xfer_interface *xfer,
26
 			    struct xfer_interface *src,
30
 			    struct xfer_interface *src,
27
 			    struct io_buffer *iobuf );
31
 			    struct io_buffer *iobuf );
32
+	/** Deliver datagram as raw data
33
+	 *
34
+	 * @v xfer		Data-transfer interface
35
+	 * @v src		Source interface
36
+	 * @v data		Data buffer
37
+	 * @v len		Length of data buffer
38
+	 * @ret rc		Return status code
39
+	 *
40
+	 * A data transfer interface that wishes to support only I/O
41
+	 * buffer delivery should set this method to
42
+	 * deliver_as_iobuf().
43
+	 */
44
+	int ( * deliver_raw ) ( struct xfer_interface *xfer,
45
+				struct xfer_interface *src,
46
+				const void *data, size_t len );
28
 };
47
 };
29
 
48
 
30
 /** A data transfer interface */
49
 /** A data transfer interface */
38
 extern struct xfer_interface null_xfer;
57
 extern struct xfer_interface null_xfer;
39
 extern struct xfer_interface_operations null_xfer_ops;
58
 extern struct xfer_interface_operations null_xfer_ops;
40
 
59
 
60
+extern int deliver_as_raw ( struct xfer_interface *xfer,
61
+			    struct xfer_interface *src,
62
+			    struct io_buffer *iobuf );
63
+extern int deliver_as_iobuf ( struct xfer_interface *xfer,
64
+			      struct xfer_interface *src,
65
+			      const void *data, size_t len );
66
+
67
+/**
68
+ * Get destination data-transfer interface
69
+ *
70
+ * @v xfer		Data-transfer interface
71
+ * @ret dest		Destination interface
72
+ */
41
 static inline struct xfer_interface *
73
 static inline struct xfer_interface *
42
 xfer_dest ( struct xfer_interface *xfer ) {
74
 xfer_dest ( struct xfer_interface *xfer ) {
43
 	return container_of ( xfer->intf.dest, struct xfer_interface, intf );
75
 	return container_of ( xfer->intf.dest, struct xfer_interface, intf );

Loading…
Cancel
Save