mirror of
https://github.com/ipxe/ipxe
synced 2025-12-15 00:12:19 +03:00
[image] Provide image_memory()
Consolidate the remaining logic common to initrd_init() and imgmem() into a shared image_memory() function. Signed-off-by: Michael Brown <mcb30@ipxe.org>
This commit is contained in:
@@ -173,43 +173,20 @@ void imgstat ( struct image *image ) {
|
||||
/**
|
||||
* Create image from block of memory
|
||||
*
|
||||
* @v name Name
|
||||
* @v data Image data
|
||||
* @v len Length
|
||||
* @v name Name
|
||||
* @v image Image to fill in
|
||||
* @ret rc Return status code
|
||||
*/
|
||||
int imgmem ( userptr_t data, size_t len, const char *name,
|
||||
struct image **image ) {
|
||||
int rc;
|
||||
int imgmem ( const char *name, userptr_t data, size_t len ) {
|
||||
struct image *image;
|
||||
|
||||
/* Allocate image */
|
||||
*image = alloc_image ( NULL );
|
||||
if ( ! *image ) {
|
||||
rc = -ENOMEM;
|
||||
goto err_alloc_image;
|
||||
/* Create image */
|
||||
image = image_memory ( name, data, len );
|
||||
if ( ! image ) {
|
||||
printf ( "Could not create image\n" );
|
||||
return -ENOMEM;
|
||||
}
|
||||
|
||||
/* Set name */
|
||||
if ( ( rc = image_set_name ( *image, name ) ) != 0 )
|
||||
goto err_set_name;
|
||||
|
||||
/* Set data */
|
||||
if ( ( rc = image_set_data ( *image, data, len ) ) != 0 ) {
|
||||
printf ( "Could not set image data: %s\n", strerror ( rc ) );
|
||||
goto err_set_data;
|
||||
}
|
||||
|
||||
/* Register image */
|
||||
if ( ( rc = register_image ( *image ) ) != 0 ) {
|
||||
printf ( "Could not register image: %s\n", strerror ( rc ) );
|
||||
goto err_register_image;
|
||||
}
|
||||
|
||||
err_register_image:
|
||||
err_set_data:
|
||||
err_set_name:
|
||||
image_put ( *image );
|
||||
err_alloc_image:
|
||||
return rc;
|
||||
return 0;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user