summaryrefslogtreecommitdiffstats
path: root/src/core/downloader.c
diff options
context:
space:
mode:
authorMichael Brown2007-06-09 18:42:46 +0200
committerMichael Brown2007-06-09 18:42:46 +0200
commit7c8cc3ef6cfdacdb6dcf1f556070069f8446e64b (patch)
tree9014b799af187b81962f20efd4d9d8914f385971 /src/core/downloader.c
parentAdd reference counting to register/unregister procedure. (diff)
downloadipxe-7c8cc3ef6cfdacdb6dcf1f556070069f8446e64b.tar.gz
ipxe-7c8cc3ef6cfdacdb6dcf1f556070069f8446e64b.tar.xz
ipxe-7c8cc3ef6cfdacdb6dcf1f556070069f8446e64b.zip
Use standard xfer_open() argument list for downloader instantiator
Diffstat (limited to 'src/core/downloader.c')
-rw-r--r--src/core/downloader.c17
1 files changed, 11 insertions, 6 deletions
diff --git a/src/core/downloader.c b/src/core/downloader.c
index 15ef962d..eec0c578 100644
--- a/src/core/downloader.c
+++ b/src/core/downloader.c
@@ -17,6 +17,7 @@
*/
#include <stdlib.h>
+#include <stdarg.h>
#include <errno.h>
#include <gpxe/xfer.h>
#include <gpxe/open.h>
@@ -243,19 +244,21 @@ static struct xfer_interface_operations downloader_xfer_operations = {
* Instantiate a downloader
*
* @v job Job control interface
- * @v uri_string URI string
* @v image Image to fill with downloaded file
* @v register_image Image registration routine
+ * @v type Location type to pass to xfer_open()
+ * @v ... Remaining arguments to pass to xfer_open()
* @ret rc Return status code
*
* Instantiates a downloader object to download the specified URI into
* the specified image object. If the download is successful, the
* image registration routine @c register_image() will be called.
*/
-int create_downloader ( struct job_interface *job, const char *uri_string,
- struct image *image,
- int ( * register_image ) ( struct image *image ) ) {
+int create_downloader ( struct job_interface *job, struct image *image,
+ int ( * register_image ) ( struct image *image ),
+ int type, ... ) {
struct downloader *downloader;
+ va_list args;
int rc;
/* Allocate and initialise structure */
@@ -270,19 +273,21 @@ int create_downloader ( struct job_interface *job, const char *uri_string,
&downloader->refcnt );
downloader->image = image_get ( image );
downloader->register_image = register_image;
+ va_start ( args, type );
/* Instantiate child objects and attach to our interfaces */
- if ( ( rc = xfer_open ( &downloader->xfer, LOCATION_URI,
- uri_string ) ) != 0 )
+ if ( ( rc = xfer_vopen ( &downloader->xfer, type, args ) ) != 0 )
goto err;
/* Attach parent interface, mortalise self, and return */
job_plug_plug ( &downloader->job, job );
ref_put ( &downloader->refcnt );
+ va_end ( args );
return 0;
err:
downloader_finished ( downloader, rc );
ref_put ( &downloader->refcnt );
+ va_end ( args );
return rc;
}