mirror of
https://github.com/ipxe/ipxe
synced 2025-12-22 13:00:39 +03:00
Add start() event
Add "xfer" to all xfer functions and "job" to all job functions.
This commit is contained in:
@@ -33,6 +33,11 @@ struct job_interface;
|
||||
|
||||
/** Job control interface operations */
|
||||
struct job_interface_operations {
|
||||
/** Start job
|
||||
*
|
||||
* @v job Job control interface
|
||||
*/
|
||||
void ( * start ) ( struct job_interface *job );
|
||||
/** Job completed
|
||||
*
|
||||
* @v job Job control interface
|
||||
@@ -64,12 +69,13 @@ struct job_interface {
|
||||
extern struct job_interface null_job;
|
||||
extern struct job_interface_operations null_job_ops;
|
||||
|
||||
extern void done ( struct job_interface *job, int rc );
|
||||
extern void job_done ( struct job_interface *job, int rc );
|
||||
|
||||
extern void ignore_done ( struct job_interface *job, int rc );
|
||||
extern void ignore_kill ( struct job_interface *job );
|
||||
extern void ignore_progress ( struct job_interface *job,
|
||||
struct job_progress *progress );
|
||||
extern void ignore_job_start ( struct job_interface *job );
|
||||
extern void ignore_job_done ( struct job_interface *job, int rc );
|
||||
extern void ignore_job_kill ( struct job_interface *job );
|
||||
extern void ignore_job_progress ( struct job_interface *job,
|
||||
struct job_progress *progress );
|
||||
|
||||
/**
|
||||
* Initialise a job control interface
|
||||
@@ -108,6 +114,37 @@ job_dest ( struct job_interface *job ) {
|
||||
return intf_to_job ( job->intf.dest );
|
||||
}
|
||||
|
||||
/**
|
||||
* Plug a job control interface into a new destination interface
|
||||
*
|
||||
* @v job Job control interface
|
||||
* @v dest New destination interface
|
||||
*/
|
||||
static inline void job_plug ( struct job_interface *job,
|
||||
struct job_interface *dest ) {
|
||||
plug ( &job->intf, &dest->intf );
|
||||
}
|
||||
|
||||
/**
|
||||
* Plug two job control interfaces together
|
||||
*
|
||||
* @v a Job control interface A
|
||||
* @v b Job control interface B
|
||||
*/
|
||||
static inline void job_plug_plug ( struct job_interface *a,
|
||||
struct job_interface *b ) {
|
||||
plug_plug ( &a->intf, &b->intf );
|
||||
}
|
||||
|
||||
/**
|
||||
* Unplug a job control interface
|
||||
*
|
||||
* @v job Job control interface
|
||||
*/
|
||||
static inline void job_unplug ( struct job_interface *job ) {
|
||||
plug ( &job->intf, &null_job.intf );
|
||||
}
|
||||
|
||||
/**
|
||||
* Stop using a job control interface
|
||||
*
|
||||
|
||||
@@ -21,15 +21,17 @@ struct xfer_interface_operations {
|
||||
*
|
||||
* notification of non-close status - e.g. connected/opened, ...
|
||||
*
|
||||
* seek
|
||||
*
|
||||
* prompt for data delivery
|
||||
*
|
||||
* I/O buffer preparation
|
||||
*
|
||||
*/
|
||||
|
||||
|
||||
/** Start data transfer
|
||||
*
|
||||
* @v xfer Data transfer interface
|
||||
*/
|
||||
void ( * start ) ( struct xfer_interface *xfer );
|
||||
/** Close interface
|
||||
*
|
||||
* @v xfer Data transfer interface
|
||||
@@ -60,7 +62,7 @@ struct xfer_interface_operations {
|
||||
*
|
||||
* A data transfer interface that wishes to support only raw
|
||||
* data delivery should set this method to
|
||||
* deliver_as_raw().
|
||||
* xfer_deliver_as_raw().
|
||||
*/
|
||||
int ( * deliver ) ( struct xfer_interface *xfer,
|
||||
struct io_buffer *iobuf );
|
||||
@@ -73,7 +75,7 @@ struct xfer_interface_operations {
|
||||
*
|
||||
* A data transfer interface that wishes to support only I/O
|
||||
* buffer delivery should set this method to
|
||||
* deliver_as_iobuf().
|
||||
* xfer_deliver_as_iobuf().
|
||||
*/
|
||||
int ( * deliver_raw ) ( struct xfer_interface *xfer,
|
||||
const void *data, size_t len );
|
||||
@@ -90,24 +92,30 @@ struct xfer_interface {
|
||||
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,
|
||||
extern void xfer_start ( struct xfer_interface *xfer );
|
||||
extern void xfer_close ( struct xfer_interface *xfer, int rc );
|
||||
extern int xfer_seek ( struct xfer_interface *xfer, size_t pos );
|
||||
extern int xfer_vredirect ( struct xfer_interface *xfer, int type,
|
||||
va_list args );
|
||||
extern int xfer_redirect ( struct xfer_interface *xfer, int type, ... );
|
||||
extern int xfer_deliver ( struct xfer_interface *xfer,
|
||||
struct io_buffer *iobuf );
|
||||
extern int xfer_deliver_raw ( 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 );
|
||||
|
||||
extern void ignore_xfer_start ( struct xfer_interface *xfer );
|
||||
extern void ignore_xfer_close ( struct xfer_interface *xfer, int rc );
|
||||
extern int ignore_xfer_vredirect ( struct xfer_interface *xfer,
|
||||
int type, va_list args );
|
||||
extern int default_xfer_vredirect ( struct xfer_interface *xfer,
|
||||
int type, va_list args );
|
||||
extern int ignore_xfer_seek ( struct xfer_interface *xfer, size_t pos );
|
||||
extern int xfer_deliver_as_raw ( struct xfer_interface *xfer,
|
||||
struct io_buffer *iobuf );
|
||||
extern int xfer_deliver_as_iobuf ( struct xfer_interface *xfer,
|
||||
const void *data, size_t len );
|
||||
extern int ignore_xfer_deliver_raw ( struct xfer_interface *xfer,
|
||||
const void *data __unused, size_t len );
|
||||
|
||||
/**
|
||||
* Initialise a data transfer interface
|
||||
@@ -157,6 +165,17 @@ static inline void xfer_plug ( struct xfer_interface *xfer,
|
||||
plug ( &xfer->intf, &dest->intf );
|
||||
}
|
||||
|
||||
/**
|
||||
* Plug two data transfer interfaces together
|
||||
*
|
||||
* @v a Data transfer interface A
|
||||
* @v b Data transfer interface B
|
||||
*/
|
||||
static inline void xfer_plug_plug ( struct xfer_interface *a,
|
||||
struct xfer_interface *b ) {
|
||||
plug_plug ( &a->intf, &b->intf );
|
||||
}
|
||||
|
||||
/**
|
||||
* Unplug a data transfer interface
|
||||
*
|
||||
|
||||
Reference in New Issue
Block a user