help-grub
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: Obtaining the MAC address of the boot NIC for a PXE boot


From: Rigoberto Corujo
Subject: Re: Obtaining the MAC address of the boot NIC for a PXE boot
Date: Wed, 8 May 2013 10:27:47 -0700 (PDT)

----- Original Message -----

> From: Andrey Borzenkov <address@hidden>
> To: Rigoberto Corujo <address@hidden>
> Cc: "address@hidden" <address@hidden>; address@hidden
> Sent: Wednesday, May 1, 2013 10:59 AM
> Subject: Re: Obtaining the MAC address of the boot NIC for a PXE boot
> 
> В Mon, 29 Apr 2013 05:55:32 -0700 (PDT)
> Rigoberto Corujo <address@hidden> пишет:
> 
>>  Hello everyone,
>> 
>>  With pxelinux, you can specify "IPAPPEND 2" in your boot loader 
> configuration file and the MAC address of the boot NIC automatically gets 
> appended to your kernel parameters as "BOOTIF=XX:XX:XX:XX:XX:XX". 
>> 
>>  I am now trying to become familiar with Grub 2, because if its EFI support. 
>   I noticed that with Grub 2, some of the documentation, which may be 
> outdated, 
> says that there is a "net_pxe_mac" variable which, as I understand it, 
> should contain the MAC address of the boot NIC.  However, I've built the 
> latest Grub 2 sources and, when I PXE boot and drop into a grub shell prompt, 
> if 
> type "set", I don't see "net_pxe_mac" listed as one of 
> the variables.  I know there is a "net_ls_addr" command which prints 
> out something like "efinet8 3c:4a:92:b2:6a:e8 10.1.1.114", but I 
> don't know how to use Grub scripting to parse out the MAC address.  I also 
> don't know if there will ever be a case where "net_ls_addr" will 
> print out multiple entries on a PXE boot, making it difficult to determine 
> which 
> one corresponds to the boot NIC.
>> 
>> 
>>  Basically, I'm using the "ksdevice=bootif" kernel parameter 
> when PXE booting my Red Hat kernel.  With PXE Linux, "bootif" provides 
> the MAC address of the boot NIC.  I was hoping to do something like 
> "ksdevice=${net_pxe_mac}", but since "net_pxe_mac" does not 
> appear to be getting set, I need to find some other method.
>> 
> 
> 
> As it stands currently, net_pxe_* variables are defined on PC BIOS
> platform only. For UEFI (which you apparently have) GRUB2 defines
> net_efinetNN_* variables where efinetNN is symbolic name for interface
> that was used to boot GRUB2.
> 
> May be GRUB2 should also define net_pxe_* namespace for the case of
> UEFI. There is no real way to find out which interface was used for
> booting and even if there were, grub does not support nested
> variables substitution or eval'ing (like ${net_${boot_if}_mac).
> 
> Probably, adding "eval" support is really the most simple. Could you
> test the patch below. What it does, is
> 
> - it adds "eval" command (same as known from UNIX shells) which
>   executes its argument
> 
> - it exports boot interface as "efi_boot_interface" variable
> 
> This should allow you to do
> 
> if $grub_platform = efi ; then
>   eval "set net_pxe_mac=\$net_${efi_boot_interface}_mac" 
> fi
> 
> and then use $net_pxe_mac on both platforms.
> 
> If it works for you, I will clean it up; for consistency this is
> probably needed for ieee1275 as well.
> 
> ---
> grub-core/Makefile.core.def        |  5 ++++
> grub-core/commands/eval.c          | 51 ++++++++++++++++++++++++++++++++++++++
> grub-core/net/drivers/efi/efinet.c |  2 ++
> 3 files changed, 58 insertions(+)
> 
> diff --git a/grub-core/Makefile.core.def b/grub-core/Makefile.core.def
> index 7e19acb..8844f2f 100644
> --- a/grub-core/Makefile.core.def
> +++ b/grub-core/Makefile.core.def
> @@ -699,6 +699,11 @@ module = {
> };
> 
> module = {
> +  name = eval;
> +  common = commands/eval.c;
> +};
> +
> +module = {
>    name = extcmd;
>    common = commands/extcmd.c;
>    common = lib/arg.c;
> diff --git a/grub-core/commands/eval.c b/grub-core/commands/eval.c
> new file mode 100644
> index 0000000..a21ff89
> --- /dev/null
> +++ b/grub-core/commands/eval.c
> @@ -0,0 +1,51 @@
> +/*
> + *  GRUB  --  GRand Unified Bootloader
> + *  Copyright (C) 2009  Free Software Foundation, Inc.
> + *
> + *  GRUB 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 3 of the License, or
> + *  (at your option) any later version.
> + *
> + *  GRUB 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 GRUB.  If not, see <http://www.gnu.org/licenses/>.
> + */
> +
> +#include <grub/dl.h>
> +#include <grub/misc.h>
> +#include <grub/extcmd.h>
> +#include <grub/i18n.h>
> +#include <grub/term.h>
> +
> +GRUB_MOD_LICENSE ("GPLv3+");
> +
> +static grub_err_t
> +grub_cmd_eval (grub_extcmd_context_t ctxt __attribute__((__unused__)),
> +           int argc, char *argv[])
> +{
> +  char *dummy[1] = { NULL };
> +
> +  if (argc != 1)
> +    return  grub_error (GRUB_ERR_BAD_ARGUMENT, N_("one argument 
> expected"));
> +  return grub_script_execute_sourcecode (argv[0], 0, dummy);
> +}
> +
> +static grub_extcmd_t cmd;
> +
> +GRUB_MOD_INIT(eval)
> +{
> +  cmd = grub_register_extcmd ("eval", grub_cmd_eval, 0,
> +                  N_("[STRING]"), N_("Evaluate commands"),
> +                              NULL);
> +}
> +
> +GRUB_MOD_FINI(eval)
> +{
> +  grub_unregister_extcmd (cmd);
> +}
> +
> diff --git a/grub-core/net/drivers/efi/efinet.c 
> b/grub-core/net/drivers/efi/efinet.c
> index 2b344d6..f7d8fd5 100644
> --- a/grub-core/net/drivers/efi/efinet.c
> +++ b/grub-core/net/drivers/efi/efinet.c
> @@ -23,6 +23,7 @@
> #include <grub/efi/api.h>
> #include <grub/efi/efi.h>
> #include <grub/i18n.h>
> +#include <grub/env.h>
> 
> GRUB_MOD_LICENSE ("GPLv3+");
> 
> @@ -250,6 +251,7 @@ grub_efi_net_config_real (grub_efi_handle_t hnd, char 
> **device,
>                     &pxe_mode->dhcp_ack,
>                     sizeof (pxe_mode->dhcp_ack),
>                     1, device, path);
> +    grub_env_set ("efi_boot_interface", card->name);
>      return;
>    }
> }
> -- 
> tg: (93daf86..) e/uefi_pxe_vars (depends on: master)
> 
> 
> _______________________________________________
> Help-grub mailing list
> address@hidden
> https://lists.gnu.org/mailman/listinfo/help-grub
> 

Thank you very much, Andrey.  This worked.  I did have to add the following 
lines to "grub-core/Makefile.core.am" to get a "eval.mod" generated, but I'm 
sure that it's probably because I missed an important step that would have 
automatically generated it.


if COND_x86_64_efi
platform_PROGRAMS += eval.module
MODULE_FILES += eval.module$(EXEEXT)
eval_module_SOURCES  = commands/eval.c  ## platform sources
nodist_eval_module_SOURCES  =  ## platform nodist sources
eval_module_LDADD  =
eval_module_CFLAGS  = $(AM_CFLAGS) $(CFLAGS_MODULE)
eval_module_LDFLAGS  = $(AM_LDFLAGS) $(LDFLAGS_MODULE)
eval_module_CPPFLAGS  = $(AM_CPPFLAGS) $(CPPFLAGS_MODULE)
eval_module_CCASFLAGS  = $(AM_CCASFLAGS) $(CCASFLAGS_MODULE)
EXTRA_DIST +=
BUILT_SOURCES += $(nodist_eval_module_SOURCES)
CLEANFILES += $(nodist_eval_module_SOURCES)
MOD_FILES += eval.mod
MARKER_FILES += eval.marker
CLEANFILES += eval.marker

eval.marker: $(eval_module_SOURCES) $(nodist_eval_module_SOURCES)
        $(TARGET_CPP) -DGRUB_LST_GENERATOR $(CPPFLAGS_MARKER) $(DEFS) 
$(DEFAULT_INCLUDES) $(INCLUDES) $(eval_module_CPPFLAGS) $(CPPFLAGS) $^ > 
address@hidden || (rm -f $@; exit 1)
        grep 'MARKER' address@hidden > $@; rm -f address@hidden
endif

Anyway, thank you once again.

Rigoberto




reply via email to

[Prev in Thread] Current Thread [Next in Thread]