#include <ipxe/init.h>
#include <ipxe/image.h>
#include <ipxe/script.h>
-#include <ipxe/umalloc.h>
#include <realmode.h>
/** Command line physical address
rc = -ENOMEM;
goto err_alloc_image;
}
+
+ /* Set image name */
if ( ( rc = image_set_name ( image, "<INITRD>" ) ) != 0 ) {
DBGC ( colour, "RUNTIME could not set image name: %s\n",
strerror ( rc ) );
goto err_set_name;
}
- /* Allocate and copy initrd content */
- image->data = umalloc ( initrd_len );
- if ( ! image->data ) {
- DBGC ( colour, "RUNTIME could not allocate %d bytes for "
- "initrd\n", initrd_len );
- rc = -ENOMEM;
- goto err_umalloc;
+ /* Set image content */
+ if ( ( rc = image_set_data ( image, phys_to_user ( initrd_phys ),
+ initrd_len ) ) != 0 ) {
+ DBGC ( colour, "RUNTIME could not set image data: %s\n",
+ strerror ( rc ) );
+ goto err_set_data;
}
- image->len = initrd_len;
- memcpy_user ( image->data, 0, phys_to_user ( initrd_phys ), 0,
- initrd_len );
/* Mark initrd as consumed */
initrd_phys = 0;
return 0;
err_register_image:
- err_umalloc:
+ err_set_data:
err_set_name:
image_put ( image );
err_alloc_image:
return 0;
}
+/**
+ * Set image data
+ *
+ * @v image Image
+ * @v data Image data
+ * @v len Length of image data
+ * @ret rc Return status code
+ */
+int image_set_data ( struct image *image, userptr_t data, size_t len ) {
+ userptr_t new;
+
+ /* (Re)allocate image data */
+ new = urealloc ( image->data, len );
+ if ( ! new )
+ return -ENOMEM;
+ image->data = new;
+
+ /* Copy in new image data */
+ memcpy_user ( image->data, 0, data, 0, len );
+ image->len = len;
+
+ return 0;
+}
+
/**
* Determine image type
*
extern int image_set_uri ( struct image *image, struct uri *uri );
extern int image_set_name ( struct image *image, const char *name );
extern int image_set_cmdline ( struct image *image, const char *cmdline );
+extern int image_set_data ( struct image *image, userptr_t data, size_t len );
extern int register_image ( struct image *image );
extern void unregister_image ( struct image *image );
struct image * find_image ( const char *name );