I prefer IMAGE_XXX to XXX_IMAGE.
authorMichael Brown <mcb30@etherboot.org>
Sat, 13 Jan 2007 17:28:51 +0000 (17:28 +0000)
committerMichael Brown <mcb30@etherboot.org>
Sat, 13 Jan 2007 17:28:51 +0000 (17:28 +0000)
Add IMAGE_PXE to use the new image format framework.  "kernel pxelinux.0"
now works.

src/arch/i386/image/pxe_image.c [new file with mode: 0644]
src/config.h
src/core/config.c

diff --git a/src/arch/i386/image/pxe_image.c b/src/arch/i386/image/pxe_image.c
new file mode 100644 (file)
index 0000000..f88c459
--- /dev/null
@@ -0,0 +1,83 @@
+/*
+ * Copyright (C) 2007 Michael Brown <mbrown@fensystems.co.uk>.
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation; either version 2 of the
+ * License, or any later version.
+ *
+ * This program is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+ */
+
+/**
+ * @file
+ *
+ * PXE image format
+ *
+ */
+
+#include <gpxe/uaccess.h>
+#include <gpxe/image.h>
+#include <gpxe/segment.h>
+#include <pxe_call.h>
+
+/** PXE load address segment */
+#define PXE_LOAD_SEGMENT 0
+
+/** PXE load address offset */
+#define PXE_LOAD_OFFSET 0x7c00
+
+struct image_type pxe_image_type __image_type ( PROBE_PXE );
+
+/**
+ * Execute PXE image
+ *
+ * @v image            PXE image
+ * @ret rc             Return status code
+ */
+static int pxe_exec ( struct image *image __unused ) {
+       return pxe_boot();
+}
+
+/**
+ * Load PXE image into memory
+ *
+ * @v image            PXE file
+ * @ret rc             Return status code
+ */
+int pxe_load ( struct image *image ) {
+       userptr_t buffer = real_to_user ( 0, 0x7c00 );
+       size_t filesz = image->len;
+       size_t memsz = image->len;
+       int rc;
+
+       /* There are no signature checks for PXE; we will accept anything */
+       if ( ! image->type )
+               image->type = &pxe_image_type;
+
+       /* Verify and prepare segment */
+       if ( ( rc = prep_segment ( buffer, filesz, memsz ) != 0 ) ) {
+               DBG ( "PXE image could not prepare segment: %s\n",
+                     strerror ( rc ) );
+               return rc;
+       }
+
+       /* Copy image to segment */
+       memcpy_user ( buffer, 0, image->data, 0, filesz );
+
+       return 0;
+}
+
+/** PXE image type */
+struct image_type pxe_image_type __image_type ( PROBE_PXE ) = {
+       .name = "PXE",
+       .load = pxe_load,
+       .exec = pxe_exec,
+};
index b8ab929..a219d64 100644 (file)
  * you want to use.
  *
  */
-#undef TAGGED_IMAGE            /* NBI image support */
-#undef ELF64_IMAGE             /* ELF64 image support */
-#undef ELF_IMAGE               /* ELF image support */
-#undef COFF_IMAGE              /* COFF image support */
-#undef FREEBSD_IMAGE           /* FreeBSD kernel image support */
-#define        MULTIBOOT_IMAGE         /* MultiBoot image support */
-#undef AOUT_IMAGE              /* a.out image support */
-#undef WINCE_IMAGE             /* WinCE image support */
-#undef PXE_IMAGE               /* PXE image support */
-#define SCRIPT_IMAGE           /* gPXE script image support */
+#undef IMAGE_NBI               /* NBI image support */
+#undef IMAGE_ELF64             /* ELF64 image support */
+#undef IMAGE_ELF               /* ELF image support */
+#undef IMAGE_COFF              /* COFF image support */
+#undef IMAGE_FREEBSD           /* FreeBSD kernel image support */
+#define        IMAGE_MULTIBOOT         /* MultiBoot image support */
+#undef IMAGE_AOUT              /* a.out image support */
+#undef IMAGE_WINCE             /* WinCE image support */
+#define        IMAGE_PXE               /* PXE image support */
+#define IMAGE_SCRIPT           /* gPXE script image support */
 
 /* @END general.h */ 
 
 #define        IFMGMT_CMD              /* Interface management commands */
 #define        ROUTE_CMD               /* Routing table management commands */
 #define IMAGE_CMD              /* Image management commands */
+#define DHCP_CMD               /* DHCP management commands */
 
 /* @END general.h */ 
 
index 6f113c0..b27ad6c 100644 (file)
@@ -110,34 +110,34 @@ REQUIRE_OBJECT ( nmb );
  * Drag in all requested image formats
  *
  */
-#ifdef TAGGED_IMAGE
+#ifdef IMAGE_NBI
 REQUIRE_OBJECT ( nbi );
 #endif
-#ifdef ELF64_IMAGE
+#ifdef IMAGE_ELF64
 REQUIRE_OBJECT ( elf64 );
 #endif
-#ifdef ELF_IMAGE
+#ifdef IMAGE_ELF
 REQUIRE_OBJECT ( elf );
 #endif
-#ifdef COFF_IMAGE
+#ifdef IMAGE_ELF
 REQUIRE_OBJECT ( coff );
 #endif
-#ifdef FREEBSD_IMAGE
+#ifdef IMAGE_FREEBSD
 REQUIRE_OBJECT ( freebsd );
 #endif
-#ifdef MULTIBOOT_IMAGE
+#ifdef IMAGE_MULTIBOOT
 REQUIRE_OBJECT ( multiboot );
 #endif
-#ifdef AOUT_IMAGE
+#ifdef IMAGE_AOUT
 REQUIRE_OBJECT ( aout );
 #endif
-#ifdef WINCE_IMAGE
+#ifdef IMAGE_WINCE
 REQUIRE_OBJECT ( wince );
 #endif
-#ifdef PXE_IMAGE
-REQUIRE_OBJECT ( pxe );
+#ifdef IMAGE_PXE
+REQUIRE_OBJECT ( pxe_image );
 #endif
-#ifdef SCRIPT_IMAGE
+#ifdef IMAGE_SCRIPT
 REQUIRE_OBJECT ( script );
 #endif