~darkmuggle-deactivatedaccount/ubuntu/quantal/grub2/fix-872244

« back to all changes in this revision

Viewing changes to loader/i386/linux.c

  • Committer: Bazaar Package Importer
  • Author(s): Colin Watson
  • Date: 2010-01-11 11:12:55 UTC
  • mfrom: (17.3.7 squeeze)
  • Revision ID: james.westby@ubuntu.com-20100111111255-lr8ebkqw5x41gq6j
Tags: 1.98~20100101-1ubuntu1
* Resynchronise with Debian. Remaining changes:
  - Adjust for default Ubuntu boot options ("quiet splash").
  - Default to hiding the menu; holding down Shift at boot will show it.
  - Set a monochromatic theme for Ubuntu.
  - Apply Ubuntu GRUB Legacy changes to legacy update-grub script: title,
    recovery mode, quiet option, tweak how memtest86+ is displayed, and
    use UUIDs where appropriate.
  - Conflict with grub (<< 0.97-54) as well as grub-legacy.
  - Fix backslash-escaping in merge_debconf_into_conf.
  - Remove "GNU/Linux" from default distributor string.
  - Add crashkernel= options if kdump and makedumpfile are available.
  - If other operating systems are installed, then automatically unhide
    the menu. Otherwise, if GRUB_HIDDEN_TIMEOUT is 0, then use keystatus
    if available to check whether Shift is pressed. If it is, show the
    menu, otherwise boot immediately. If keystatus is not available, then
    fall back to a short delay interruptible with Escape.
  - Allow Shift to interrupt 'sleep --interruptible'.
  - Don't display introductory message about line editing unless we're
    actually offering a shell prompt. Don't clear the screen just before
    booting if we never drew the menu in the first place.
  - Remove some verbose messages printed before reading the configuration
    file.
  - If the environment variable "quiet" is set to something other than 0,
    suppress progress messages as the kernel and initrd load. Set this for
    non-recovery kernel menu entries.
  - Add GRUB_DEFAULT=saved, as well as grub-set-default and grub-reboot
    utilities. Provides functionality essentially equivalent to GRUB
    Legacy's savedefault.
  - Keep the loopback file open so that subsequent changes to the "root"
    environment variable don't affect it.
  - Change prepare_grub_to_access_device to handle filesystems
    loop-mounted on file images.
  - Ignore devices loop-mounted from files in 10_linux.
  - Show the boot menu if the previous boot failed, that is if it failed
    to get to the end of one of the normal runlevels.
  - Handle RAID devices containing virtio components.
* Update savedefault patch from current Bazaar branch, fixing grub-reboot
  to have distinct behaviour from grub-set-default (LP: #497326).
* Fix grub-mkisofs compilation error with FORTIFY_SOURCE.
* Convert recordfail boilerplate in each menu entry to use a function.

Show diffs side-by-side

added added

removed removed

Lines of Context:
673
673
  len = 0x400 - sizeof (lh);
674
674
  if (grub_file_read (file, (char *) real_mode_mem + sizeof (lh), len) != len)
675
675
    {
676
 
      grub_error (GRUB_ERR_FILE_READ_ERROR, "Couldn't read file");
 
676
      grub_error (GRUB_ERR_FILE_READ_ERROR, "couldn't read file");
677
677
      goto fail;
678
678
    }
679
679
 
862
862
 
863
863
  len = prot_size;
864
864
  if (grub_file_read (file, (void *) GRUB_LINUX_BZIMAGE_ADDR, len) != len)
865
 
    grub_error (GRUB_ERR_FILE_READ_ERROR, "Couldn't read file");
 
865
    grub_error (GRUB_ERR_FILE_READ_ERROR, "couldn't read file");
866
866
 
867
867
  if (grub_errno == GRUB_ERR_NONE)
868
868
    {
897
897
 
898
898
  if (argc == 0)
899
899
    {
900
 
      grub_error (GRUB_ERR_BAD_ARGUMENT, "No module specified");
 
900
      grub_error (GRUB_ERR_BAD_ARGUMENT, "no module specified");
901
901
      goto fail;
902
902
    }
903
903
 
904
904
  if (! loaded)
905
905
    {
906
 
      grub_error (GRUB_ERR_BAD_ARGUMENT, "You need to load the kernel first.");
 
906
      grub_error (GRUB_ERR_BAD_ARGUMENT, "you need to load the kernel first");
907
907
      goto fail;
908
908
    }
909
909
 
951
951
 
952
952
  if (addr < addr_min)
953
953
    {
954
 
      grub_error (GRUB_ERR_OUT_OF_RANGE, "The initrd is too big");
 
954
      grub_error (GRUB_ERR_OUT_OF_RANGE, "the initrd is too big");
955
955
      goto fail;
956
956
    }
957
957
 
959
959
 
960
960
  if (grub_file_read (file, initrd_mem, size) != size)
961
961
    {
962
 
      grub_error (GRUB_ERR_FILE_READ_ERROR, "Couldn't read file");
 
962
      grub_error (GRUB_ERR_FILE_READ_ERROR, "couldn't read file");
963
963
      goto fail;
964
964
    }
965
965
 
982
982
GRUB_MOD_INIT(linux)
983
983
{
984
984
  cmd_linux = grub_register_command ("linux", grub_cmd_linux,
985
 
                                     0, "load linux");
 
985
                                     0, "Load Linux.");
986
986
  cmd_initrd = grub_register_command ("initrd", grub_cmd_initrd,
987
 
                                      0, "load initrd");
 
987
                                      0, "Load initrd.");
988
988
  my_mod = mod;
989
989
}
990
990