1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
|
/* Test program for byte registers.
Copyright 2010-2015 Free Software Foundation, Inc.
This file is part of GDB.
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 3 of the License, or
(at your option) 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, see <http://www.gnu.org/licenses/>. */
#include <stdio.h>
int data[] = {
0x14131211,
0x24232221,
0x34333231,
0x44434241,
0x54535251,
0x64636261,
0x74737271,
0x84838281,
0x94939291,
0xa4a3a2a1,
0xb4b3b2b1,
0xc4c3c2c1,
0xd4d3d2d1,
0xe4e3e2e1,
};
int
main (int argc, char **argv)
{
register int eax asm ("eax");
register int ebx asm ("ebx");
register int ecx asm ("ecx");
register int edx asm ("edx");
register int esi asm ("esi");
register int edi asm ("edi");
register long r8 asm ("r8");
register long r9 asm ("r9");
register long r10 asm ("r10");
register long r11 asm ("r11");
register long r12 asm ("r12");
register long r13 asm ("r13");
register long r14 asm ("r14");
register long r15 asm ("r15");
asm ("mov 0(%0), %%eax\n\t"
"mov 4(%0), %%ebx\n\t"
"mov 8(%0), %%ecx\n\t"
"mov 12(%0), %%edx\n\t"
"mov 16(%0), %%esi\n\t"
"mov 20(%0), %%edi\n\t"
: /* no output operands */
: "r" (data)
: "eax", "ebx", "ecx", "edx", "esi", "edi");
asm ("nop"); /* first breakpoint here */
asm ("mov 24(%0), %%r8d\n\t"
"mov 28(%0), %%r9d\n\t"
"mov 32(%0), %%r10d\n\t"
"mov 36(%0), %%r11\n\t"
"mov 40(%0), %%r12d\n\t"
"mov 44(%0), %%r13d\n\t"
"mov 48(%0), %%r14d\n\t"
"mov 52(%0), %%r15d\n\t"
: /* no output operands */
: "r" (data)
: "r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15");
asm ("nop" /* second breakpoint here */
/* amd64-{byte,word,dword}.exp write eax-edi here.
Tell gcc/clang they're live. */
: "=r" (eax), "=r" (ebx), "=r" (ecx),
"=r" (edx), "=r" (esi), "=r" (edi)
: /* no inputs */);
asm ("mov %%eax, 0(%0)\n\t"
"mov %%ebx, 4(%0)\n\t"
"mov %%ecx, 8(%0)\n\t"
"mov %%edx, 12(%0)\n\t"
"mov %%esi, 16(%0)\n\t"
"mov %%edi, 20(%0)\n\t"
: /* no output operands */
: "r" (data),
/* Mark these as inputs so that gcc/clang won't try to use them as
a temp to build %0. */
"r" (eax), "r" (ebx), "r" (ecx),
"r" (edx), "r" (esi), "r" (edi));
asm ("nop" /* third breakpoint here */
/* amd64-{byte,word,dword}.exp write r8-r15 here.
Tell gcc/clang they're live. */
: "=r" (r8), "=r" (r9), "=r" (r10), "=r" (r11),
"=r" (r12), "=r" (r13), "=r" (r14), "=r" (r15)
: /* no inputs */);
asm ("mov %%r8d, 24(%0)\n\t"
"mov %%r9d, 28(%0)\n\t"
"mov %%r10d, 32(%0)\n\t"
"mov %%r11d, 36(%0)\n\t"
"mov %%r12d, 40(%0)\n\t"
"mov %%r13d, 44(%0)\n\t"
"mov %%r14d, 48(%0)\n\t"
"mov %%r15d, 52(%0)\n\t"
: /* no output operands */
: "r" (data),
/* Mark these as inputs so that gcc/clang won't try to use them as
a temp to build %0. */
"r" (r8), "r" (r9), "r" (r10), "r" (r11),
"r" (r12), "r" (r13), "r" (r14), "r" (r15));
puts ("Bye!"); /* forth breakpoint here */
return 0;
}
|