Move include/image.h to include/gpxe/image.h
authorMichael Brown <mcb30@etherboot.org>
Thu, 11 Jan 2007 16:04:36 +0000 (16:04 +0000)
committerMichael Brown <mcb30@etherboot.org>
Thu, 11 Jan 2007 16:04:36 +0000 (16:04 +0000)
src/arch/i386/image/nbi.c
src/core/config.c
src/core/image.c
src/core/main.c
src/include/gpxe/image.h [new file with mode: 0644]
src/include/image.h [deleted file]

index edaaedc..6b00f5f 100644 (file)
@@ -1,13 +1,12 @@
-#include "image.h"
+#warning "This file is obsolete"
+#if 0
+
 #include "memsizes.h"
 #include "realmode.h"
 #include "gateA20.h"
 #include "etherboot.h"
 #include "errno.h"
 
-#warning "This file is obsolete"
-#if 0
-
 /** @file
  *
  * NBI image format.
index 61ffca8..e2b1a36 100644 (file)
@@ -8,7 +8,6 @@
 #include "etherboot.h"
 #include "dev.h"
 #include "console.h"
-#include "image.h"
 
 #include "config/general.h"
 
index 965af5a..80d3d5c 100644 (file)
@@ -1,8 +1,9 @@
 #include "dev.h"
 #include <gpxe/buffer.h>
-#include "image.h"
 #include <console.h>
 
+#if 0
+
 static struct image images[0] __image_start;
 static struct image images_end[0] __image_end;
 
@@ -18,8 +19,6 @@ void print_images ( void ) {
        }
 }
 
-#if 0
-
 /*
  * Identify the image format
  *
index a34eb88..3c0048d 100644 (file)
@@ -25,7 +25,6 @@ Literature dealing with the network protocols:
 #include "cmdline.h"
 #include "console.h"
 #include <gpxe/init.h>
-#include "image.h"
 #include <stdarg.h>
 
 #include <gpxe/device.h>
diff --git a/src/include/gpxe/image.h b/src/include/gpxe/image.h
new file mode 100644 (file)
index 0000000..cf6b7a8
--- /dev/null
@@ -0,0 +1,60 @@
+#ifndef _GPXE_IMAGE_H
+#define _GPXE_IMAGE_H
+
+/**
+ * @file
+ *
+ * Executable/loadable image formats
+ *
+ */
+
+#include <gpxe/tables.h>
+
+/** An executable or loadable image */
+struct image {
+       /** Raw file image */
+       userptr_t image;
+       /** Length of raw file image */
+       size_t len;
+
+       /** Execute method
+        *
+        * Filled in by the image loader.  If NULL, then the image
+        * cannot be executed.
+        */
+       int ( * execute ) ( struct image *image );
+       /** Entry point */
+       physaddr_t entry;
+};
+
+/** An executable or loadable image type */
+struct image_type {
+       /** Name of this image type */
+       char *name;
+       /** Load image into memory
+        *
+        * @v image             Executable/loadable image
+        * @ret rc              Return status code
+        *
+        * Load the image into memory.  The file image may be
+        * discarded after this call; the method must preserve any
+        * information it may require later (e.g. the execution
+        * address) within the @c image structure.
+        */
+       int ( * load ) ( struct image *image );
+};
+
+/** An executable or loadable image type */
+#define __image_type __table ( struct image_type, image_types, 01 )
+
+/**
+ * An unverifiable executable or loadable image type
+ *
+ * This should be used to mark image types for which there are no
+ * signature or other checks that can be used to verify the validity
+ * of the image (such as PXE images).  These will then be tried last
+ * in the list of image types.
+ */
+#define __default_image_type __table ( struct image_type, image_types, 02 )
+
+#endif /* _GPXE_IMAGE_H */
diff --git a/src/include/image.h b/src/include/image.h
deleted file mode 100644 (file)
index b86f324..0000000
+++ /dev/null
@@ -1,26 +0,0 @@
-#ifndef IMAGE_H
-#define IMAGE_H
-
-#include "stdint.h"
-#include "io.h"
-#include <gpxe/tables.h>
-#include "dev.h"
-
-struct image {
-       char *name;
-       int ( * probe ) ( physaddr_t data, off_t len, void **context );
-       int ( * load ) ( physaddr_t data, off_t len, void *context );
-       int ( * boot ) ( void *context );
-};
-
-#define __image_start          __table_start ( struct image, image )
-#define __image                        __table ( struct image, image, 01 )
-#define __default_image                __table ( struct image, image, 02 )
-#define __image_end            __table_end ( struct image, image )
-
-/* Functions in image.c */
-
-extern void print_images ( void );
-extern int autoload ( struct dev *dev, struct image **image, void **context );
-
-#endif /* IMAGE_H */