123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181 |
- #ifndef _GPXE_XFER_H
- #define _GPXE_XFER_H
-
- /** @file
- *
- * Data transfer interfaces
- *
- */
-
- #include <stddef.h>
- #include <stdarg.h>
- #include <gpxe/interface.h>
- #include <gpxe/iobuf.h>
-
- struct xfer_interface;
-
- /** Data transfer interface operations */
- struct xfer_interface_operations {
-
- /* Missing features:
- *
- * notification of non-close status - e.g. connected/opened, ...
- *
- * seek
- *
- * prompt for data delivery
- *
- * I/O buffer preparation
- *
- */
-
-
- /** Close interface
- *
- * @v xfer Data transfer interface
- * @v rc Reason for close
- */
- void ( * close ) ( struct xfer_interface *xfer, int rc );
- /** Redirect to new location
- *
- * @v xfer Data transfer interface
- * @v type New location type
- * @v args Remaining arguments depend upon location type
- * @ret rc Return status code
- */
- int ( * vredirect ) ( struct xfer_interface *xfer, int type,
- va_list args );
- /** Seek to position
- *
- * @v xfer Data transfer interface
- * @v pos New position
- * @ret rc Return status code
- */
- int ( * seek ) ( struct xfer_interface *xfer, size_t pos );
- /** Deliver datagram
- *
- * @v xfer Data transfer interface
- * @v iobuf Datagram I/O buffer
- * @ret rc Return status code
- *
- * A data transfer interface that wishes to support only raw
- * data delivery should set this method to
- * deliver_as_raw().
- */
- int ( * deliver ) ( struct xfer_interface *xfer,
- struct io_buffer *iobuf );
- /** Deliver datagram as raw data
- *
- * @v xfer Data transfer interface
- * @v data Data buffer
- * @v len Length of data buffer
- * @ret rc Return status code
- *
- * A data transfer interface that wishes to support only I/O
- * buffer delivery should set this method to
- * deliver_as_iobuf().
- */
- int ( * deliver_raw ) ( struct xfer_interface *xfer,
- const void *data, size_t len );
- };
-
- /** A data transfer interface */
- struct xfer_interface {
- /** Generic object communication interface */
- struct interface intf;
- /** Operations for received messages */
- struct xfer_interface_operations *op;
- };
-
- extern struct xfer_interface null_xfer;
- extern struct xfer_interface_operations null_xfer_ops;
-
- extern void close ( struct xfer_interface *xfer, int rc );
- extern int seek ( struct xfer_interface *xfer, size_t pos );
- extern int vredirect ( struct xfer_interface *xfer, int type, va_list args );
- extern int redirect ( struct xfer_interface *xfer, int type, ... );
- extern int deliver ( struct xfer_interface *xfer, struct io_buffer *iobuf );
- extern int deliver_raw ( struct xfer_interface *xfer,
- const void *data, size_t len );
-
- extern void ignore_close ( struct xfer_interface *xfer, int rc );
- extern int ignore_vredirect ( struct xfer_interface *xfer,
- int type, va_list args );
- extern int ignore_seek ( struct xfer_interface *xfer, size_t pos );
- extern int deliver_as_raw ( struct xfer_interface *xfer,
- struct io_buffer *iobuf );
- extern int deliver_as_iobuf ( struct xfer_interface *xfer,
- const void *data, size_t len );
- extern int ignore_deliver_raw ( struct xfer_interface *xfer,
- const void *data __unused, size_t len );
-
- /**
- * Initialise a data transfer interface
- *
- * @v xfer Data transfer interface
- * @v op Data transfer interface operations
- * @v refcnt Containing object reference counter, or NULL
- */
- static inline void xfer_init ( struct xfer_interface *xfer,
- struct xfer_interface_operations *op,
- struct refcnt *refcnt ) {
- xfer->intf.dest = &null_xfer.intf;
- xfer->intf.refcnt = refcnt;
- xfer->op = op;
- }
-
- /**
- * Get data transfer interface from generic object communication interface
- *
- * @v intf Generic object communication interface
- * @ret xfer Data transfer interface
- */
- static inline struct xfer_interface *
- intf_to_xfer ( struct interface *intf ) {
- return container_of ( intf, struct xfer_interface, intf );
- }
-
- /**
- * Get destination data transfer interface
- *
- * @v xfer Data transfer interface
- * @ret dest Destination interface
- */
- static inline struct xfer_interface *
- xfer_dest ( struct xfer_interface *xfer ) {
- return intf_to_xfer ( xfer->intf.dest );
- }
-
- /**
- * Plug a data transfer interface into a new destination interface
- *
- * @v xfer Data transfer interface
- * @v dest New destination interface
- */
- static inline void xfer_plug ( struct xfer_interface *xfer,
- struct xfer_interface *dest ) {
- plug ( &xfer->intf, &dest->intf );
- }
-
- /**
- * Unplug a data transfer interface
- *
- * @v xfer Data transfer interface
- */
- static inline void xfer_unplug ( struct xfer_interface *xfer ) {
- plug ( &xfer->intf, &null_xfer.intf );
- }
-
- /**
- * Stop using a data transfer interface
- *
- * @v xfer Data transfer interface
- *
- * After calling this method, no further messages will be received via
- * the interface.
- */
- static inline void xfer_nullify ( struct xfer_interface *xfer ) {
- xfer->op = &null_xfer_ops;
- };
-
- #endif /* _GPXE_XFER_H */
|