]>
git.ipfire.org Git - thirdparty/openssl.git/blob - crypto/perlasm/x86unix.pl
7 $align=($main'aout)?"4":"16";
8 $under=($main'aout
)?
"_":"";
9 $com_start=($main'sol)?"/":"#";
39 %regs=( 'eax', '%eax',
51 (defined($lb{$_[0]})) || die "$_[0] does not have a 'low byte
'\n";
57 (defined($hb{$_[0]})) || die "$_[0] does not have a 'high byte'\n";
63 local($addr,$reg1,$reg2,$idx)=@_;
68 $addr =~ s/(^|[+ \t])([A-Za-z_]+)($|[+ \t])/$1$under$2$3/;
70 $reg1="$regs{$reg1}" if defined($regs{$reg1});
71 $reg2="$regs{$reg2}" if defined($regs{$reg2});
72 $ret.=$addr if ($addr ne "") && ($addr ne 0);
75 $ret.="($reg1,$reg2,$idx)";
86 local($addr,$reg1,$reg2,$idx)=@_;
91 $addr =~ s/(^|[+ \t])([A-Za-z_]+)($|[+ \t])/$1$under$2$3/;
93 $reg1="$regs{$reg1}" if defined($regs{$reg1});
94 $reg2="$regs{$reg2}" if defined($regs{$reg2});
95 $ret.=$addr if ($addr ne "") && ($addr ne 0);
98 $ret.="($reg1,$reg2,$idx)";
107 sub main
'mov { &out2("movl",@_); }
108 sub main'movb
{ &out2
("movb",@_); }
109 sub main
'and { &out2("andl",@_); }
110 sub main'or { &out2
("orl",@_); }
111 sub main
'shl { &out2("sall",@_); }
112 sub main'shr
{ &out2
("shrl",@_); }
113 sub main
'xor { &out2("xorl",@_); }
114 sub main'add
{ &out2
("addl",@_); }
115 sub main
'sub { &out2("subl",@_); }
116 sub main'rotl
{ &out2
("roll",@_); }
117 sub main
'rotr { &out2("rorl",@_); }
118 sub main'exch
{ &out2
("xchg",@_); }
119 sub main
'cmp { &out2("cmpl",@_); }
120 sub main'jmp
{ &out1
("jmp",@_); }
121 sub main
'je { &out1("je",@_); }
122 sub main'jne
{ &out1
("jne",@_); }
123 sub main
'jnz { &out1("jnz",@_); }
124 sub main'jz
{ &out1
("jz",@_); }
125 sub main
'dec { &out1("decl",@_); }
126 sub main'push { &out1
("pushl",@_); }
127 sub main
'call { &out1("call",$under.$_[0]); }
132 local($name,$p1,$p2)=@_;
159 # $p =~ s/0x([0-9A-Fa-f]+)/0$1h/;
161 $p=$regs{$p} if (defined($regs{$p}));
163 $p =~ s/^([0-9A-Fa-f]+)$/\$$1/;
164 $p =~ s/^(0x[0-9A-Fa-f]+)$/\$$1/;
179 sub main
'function_begin
181 local($func,$num)=@_;
193 { printf("\tTYPE($func,\@function)\n"); }
194 else { printf("\t.type $func,\@function\n"); }
206 sub main
'function_end
221 { printf("\tSIZE($func,.${func}_end-$func)\n"); }
222 else { printf("\t.size\t$func,.${func}_end-$func\n"); }
223 print ".ident \"desasm.pl\"\n";
228 sub main'function_end_A
241 sub main
'function_end_B
251 { printf("\tSIZE($func,.${func}_end-$func)\n"); }
252 else { printf("\t.size\t$func,.${func}_end-$func\n"); }
253 print ".ident \"desasm.pl\"\n";
262 return(&main
'DWP($stack+$num*4,"esp","",0));
269 return(&main
'BP(-(($num+1)*4)+$b,"esp","",0));
276 return(&main
'DWP(-($num+1)*4,"esp","",0));
286 { print "\t$com_start $_ $com_end\n"; }
292 if (!defined($label{$_[0]}))
294 $label{$_[0]}=".${label}${_[0]}";
297 return($label{$_[0]});
302 if (!defined($label{$_[0]}))
304 $label{$_[0]}=".${label}${_[0]}";
307 print ".align $align\n";
308 print "$label{$_[0]}:\n";