2011-07-22, 17:55
I have an iPXE setup that is serving shared iSCSI boot images to legacy PC's. I am using Microsoft DHCP, Microsoft iSCSI Software Target, and Microsoft WDS all on the same Windows Server 2008 R2.
DHCP serves out thin\undionly.kpxe (downloaded from ipxe.org) first, and then thin\boot (an iPXE script) on user class iPXE to break the chain loop. The script is very simple --
#!ipxe
dhcp
clear net0.dhcp/gateway:ipv4
set root-path iscsi:${next-server}::::iqn.1991-05.com.microsoft:thin-${net0/mac:hexhyp}-target
set keep-san 1
sanboot ${root-path} ||
chain \boot\x86\wdsnbp.com ||
This works great, and allows me to boot automatically from an iSCSI target that is named based on the client's MAC address, or drop into WinRE when no such target exists (or when the target exists but has no bootable OS, which also supports Windows installation directly to the iSCSI target via WDS).
However, I periodically need to run memtest or do a BIOS flash and would like to use the network to accomplish this (have to, actually, as the machines have no hard, CD/DVD, or floppy drives).
The idea was to put PXELINUX.0 and MEMDISK in the same directory (tftproot of thin\), create a pxelinux.cfg directory with a single file named "default" providing me with a prompt and some .iso and .img initrd choices, and use ctrl-B from iPXE to chain "as needed" into this maintenance setup.
If I change DHCP to serve up PXELINUX.0 directly, this works excellent and I can drop into MEMTEST86 or whatever.
However, if I ctrl-B from iPXE and type
DHCP
CHAIN thin\pxelinux.0
I see my prompt, and when I select memtest (or anything else), I get
Loading memdisk..
Loading img\memtest86-4.0.iso....ready.
iPXE>
I am returned to the iPXE script prompt.
I know very little about Linux (only what I have learned in making all of this work so far).
What am I doing wrong getting undionly.kpxe to chain into pxelinux.0 properly?
Thanks in advance!
EDIT: All of my legacy PC's have the Intel Boot Agent 4.x and I'm not interested in flashing those ROM's if it can at all be avoided.
DHCP serves out thin\undionly.kpxe (downloaded from ipxe.org) first, and then thin\boot (an iPXE script) on user class iPXE to break the chain loop. The script is very simple --
#!ipxe
dhcp
clear net0.dhcp/gateway:ipv4
set root-path iscsi:${next-server}::::iqn.1991-05.com.microsoft:thin-${net0/mac:hexhyp}-target
set keep-san 1
sanboot ${root-path} ||
chain \boot\x86\wdsnbp.com ||
This works great, and allows me to boot automatically from an iSCSI target that is named based on the client's MAC address, or drop into WinRE when no such target exists (or when the target exists but has no bootable OS, which also supports Windows installation directly to the iSCSI target via WDS).
However, I periodically need to run memtest or do a BIOS flash and would like to use the network to accomplish this (have to, actually, as the machines have no hard, CD/DVD, or floppy drives).
The idea was to put PXELINUX.0 and MEMDISK in the same directory (tftproot of thin\), create a pxelinux.cfg directory with a single file named "default" providing me with a prompt and some .iso and .img initrd choices, and use ctrl-B from iPXE to chain "as needed" into this maintenance setup.
If I change DHCP to serve up PXELINUX.0 directly, this works excellent and I can drop into MEMTEST86 or whatever.
However, if I ctrl-B from iPXE and type
DHCP
CHAIN thin\pxelinux.0
I see my prompt, and when I select memtest (or anything else), I get
Loading memdisk..
Loading img\memtest86-4.0.iso....ready.
iPXE>
I am returned to the iPXE script prompt.
I know very little about Linux (only what I have learned in making all of this work so far).
What am I doing wrong getting undionly.kpxe to chain into pxelinux.0 properly?
Thanks in advance!
EDIT: All of my legacy PC's have the Intel Boot Agent 4.x and I'm not interested in flashing those ROM's if it can at all be avoided.