~ubuntu-branches/ubuntu/trusty/grub2/trusty-updates

« back to all changes in this revision

Viewing changes to grub-core/lib/x86_64/relocator_asm.S

  • Committer: Bazaar Package Importer
  • Author(s): Colin Watson
  • Date: 2011-02-08 11:39:26 UTC
  • mfrom: (17.6.26 experimental)
  • mto: (17.6.27 experimental)
  • mto: This revision was merged to the branch mainline in revision 104.
  • Revision ID: james.westby@ubuntu.com-20110208113926-clfs90haboyk9zip
Tags: 1.99~rc1-2
* Merge 1.98+20100804-13 and 1.98+20100804-14, updating translations:
  - Kazakh (Baurzhan Muftakhidinov / Timur Birsh).
* mkconfig_skip_dmcrypt.patch: Refer to GRUB_PRELOAD_MODULES rather than
  suggesting people write a /etc/grub.d/01_modules script (thanks, Jordan
  Uggla).
* Handle empty dir passed to grub_find_root_device_from_mountinfo; fixes
  grub-mkrelpath on btrfs subvolumes (LP: #712029).
* Add rootflags=subvol=<name> if / is on a btrfs subvolume (LP: #712029).
* Upload to unstable.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/*
 
2
 *  GRUB  --  GRand Unified Bootloader
 
3
 *  Copyright (C) 2009  Free Software Foundation, Inc.
 
4
 *
 
5
 *  GRUB is free software: you can redistribute it and/or modify
 
6
 *  it under the terms of the GNU General Public License as published by
 
7
 *  the Free Software Foundation, either version 3 of the License, or
 
8
 *  (at your option) any later version.
 
9
 *
 
10
 *  GRUB is distributed in the hope that it will be useful,
 
11
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 
12
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
13
 *  GNU General Public License for more details.
 
14
 *
 
15
 *  You should have received a copy of the GNU General Public License
 
16
 *  along with GRUB.  If not, see <http://www.gnu.org/licenses/>.
 
17
 */
 
18
 
 
19
#include <grub/symbol.h>
 
20
#include <grub/i386/memory.h>
 
21
 
 
22
        .p2align        2
 
23
 
 
24
VARIABLE(grub_relocator_backward_start)
 
25
        /* mov imm32, %rax */
 
26
        .byte   0x48
 
27
        .byte   0xb8
 
28
VARIABLE(grub_relocator_backward_dest)
 
29
        .long   0, 0
 
30
        movq    %rax, %rdi
 
31
 
 
32
        /* mov imm64, %rax */
 
33
        .byte   0x48
 
34
        .byte   0xb8
 
35
VARIABLE(grub_relocator_backward_src)
 
36
        .long   0, 0
 
37
        movq    %rax, %rsi
 
38
 
 
39
        /* mov imm64, %rcx */
 
40
        .byte   0x48
 
41
        .byte   0xb9
 
42
VARIABLE(grub_relocator_backward_chunk_size)
 
43
        .long   0, 0
 
44
 
 
45
        add     %rcx, %rsi
 
46
        add     %rcx, %rdi
 
47
 
 
48
        /* Backward movsb is implicitly off-by-one.  compensate that.  */
 
49
        sub     $1,     %rsi
 
50
        sub     $1,     %rdi
 
51
 
 
52
        /* Backward copy.  */
 
53
        std
 
54
 
 
55
        rep
 
56
        movsb
 
57
VARIABLE(grub_relocator_backward_end)
 
58
 
 
59
 
 
60
VARIABLE(grub_relocator_forward_start)
 
61
        /* mov imm64, %rax */
 
62
        .byte   0x48
 
63
        .byte   0xb8
 
64
VARIABLE(grub_relocator_forward_dest)
 
65
        .long   0, 0
 
66
        movq    %rax, %rdi
 
67
 
 
68
        /* mov imm64, %rax */
 
69
        .byte   0x48
 
70
        .byte   0xb8
 
71
VARIABLE(grub_relocator_forward_src)
 
72
        .long   0, 0
 
73
        movq    %rax, %rsi
 
74
 
 
75
        /* mov imm64, %rcx */
 
76
        .byte   0x48
 
77
        .byte   0xb9
 
78
VARIABLE(grub_relocator_forward_chunk_size)
 
79
        .long   0, 0
 
80
 
 
81
        /* Forward copy.  */
 
82
        cld
 
83
        rep
 
84
        movsb
 
85
VARIABLE(grub_relocator_forward_end)