3
# void des_ncbc_encrypt(input, output, length, schedule, ivec, enc)
5
# des_cblock (*output);
7
# des_key_schedule schedule;
12
# des_encrypt((DES_LONG *)tin,schedule,DES_ENCRYPT);
15
#&cbc("des_ncbc_encrypt","des_encrypt",0);
16
#&cbc("BF_cbc_encrypt","BF_encrypt","BF_encrypt",
18
#&cbc("des_ncbc_encrypt","des_encrypt","des_encrypt",
20
#&cbc("des_ede3_cbc_encrypt","des_encrypt3","des_decrypt3",
23
# When doing a cipher that needs bigendian order,
24
# for encrypt, the iv is kept in bigendian form,
25
# while for decrypt, it is kept in little endian.
28
local($name,$enc_func,$dec_func,$swap,$iv_off,$enc_off,$p1,$p2,$p3)=@_;
29
# name is the function name
30
# enc_func and dec_func and the functions to call for encrypt/decrypt
31
# swap is true if byte order needs to be reversed
32
# iv_off is parameter number for the iv
33
# enc_off is parameter number for the encrypt/decrypt flag
34
# p1,p2,p3 are the offsets for parameters to be passed to the
37
&function_begin_B($name,"");
50
$data_off+=4 if ($p1 > 0);
51
$data_off+=4 if ($p2 > 0);
52
$data_off+=4 if ($p3 > 0);
54
&mov($count, &wparam(2)); # length
56
&comment("getting iv ptr from parameter $iv_off");
57
&mov("ebx", &wparam($iv_off)); # Get iv ptr
59
&mov($in, &DWP(0,"ebx","",0));# iv[0]
60
&mov($out, &DWP(4,"ebx","",0));# iv[1]
64
&push($out); # used in decrypt for iv[1]
65
&push($in); # used in decrypt for iv[0]
67
&mov("ebx", "esp"); # This is the address of tin[2]
69
&mov($in, &wparam(0)); # in
70
&mov($out, &wparam(1)); # out
72
# We have loaded them all, how lets push things
73
&comment("getting encrypt flag from parameter $enc_off");
74
&mov("ecx", &wparam($enc_off)); # Get enc flag
77
&comment("get and push parameter $p3");
79
{ &mov("eax", &wparam($p3)); &push("eax"); }
80
else { &push("ecx"); }
84
&comment("get and push parameter $p2");
86
{ &mov("eax", &wparam($p2)); &push("eax"); }
87
else { &push("ecx"); }
91
&comment("get and push parameter $p1");
93
{ &mov("eax", &wparam($p1)); &push("eax"); }
94
else { &push("ecx"); }
96
&push("ebx"); # push data/iv
99
&jz(&label("decrypt"));
101
&and($count,0xfffffff8);
102
&mov("eax", &DWP($data_off,"esp","",0)); # load iv[0]
103
&mov("ebx", &DWP($data_off+4,"esp","",0)); # load iv[1]
105
&jz(&label("encrypt_finish"));
107
#############################################################
109
&set_label("encrypt_loop");
111
# "eax" and "ebx" hold iv (or the last cipher text)
113
&mov("ecx", &DWP(0,$in,"",0)); # load first 4 bytes
114
&mov("edx", &DWP(4,$in,"",0)); # second 4 bytes
119
&bswap("eax") if $swap;
120
&bswap("ebx") if $swap;
122
&mov(&DWP($data_off,"esp","",0), "eax"); # put in array for call
123
&mov(&DWP($data_off+4,"esp","",0), "ebx"); #
125
&call (&label("pic_point0"));
126
&set_label("pic_point0");
128
&add ("ebx", "\$_GLOBAL_OFFSET_TABLE_+[.-" . &label("pic_point0") . "]");
129
&call("$enc_func\@PLT");
131
&mov("eax", &DWP($data_off,"esp","",0));
132
&mov("ebx", &DWP($data_off+4,"esp","",0));
134
&bswap("eax") if $swap;
135
&bswap("ebx") if $swap;
137
&mov(&DWP(0,$out,"",0),"eax");
138
&mov(&DWP(4,$out,"",0),"ebx");
140
# eax and ebx are the next iv.
146
&jnz(&label("encrypt_loop"));
148
###################################################################3
149
&set_label("encrypt_finish");
150
&mov($count, &wparam(2)); # length
152
&jz(&label("finish"));
153
&call(&label("PIC_point"));
154
&set_label("PIC_point");
156
&lea("ecx",&DWP(&label("cbc_enc_jmp_table")."-".&label("PIC_point"),"edx"));
157
&mov($count,&DWP(0,"ecx",$count,4))
161
#&mov($count,&DWP(&label("cbc_enc_jmp_table"),"",$count,4));
165
&xor("edx", "edx") if $ppro; # ppro friendly
166
&movb(&HB("edx"), &BP(6,$in,"",0));
169
&movb(&HB("edx"), &BP(5,$in,"",0));
171
&movb(&LB("edx"), &BP(4,$in,"",0));
173
&mov("ecx", &DWP(0,$in,"",0));
174
&jmp(&label("ejend"));
176
&movb(&HB("ecx"), &BP(2,$in,"",0));
177
&xor("ecx", "ecx") if $ppro; # ppro friendly
180
&movb(&HB("ecx"), &BP(1,$in,"",0));
182
&movb(&LB("ecx"), &BP(0,$in,"",0));
188
&bswap("eax") if $swap;
189
&bswap("ebx") if $swap;
191
&mov(&DWP($data_off,"esp","",0), "eax"); # put in array for call
192
&mov(&DWP($data_off+4,"esp","",0), "ebx"); #
194
&call (&label("pic_point1"));
195
&set_label("pic_point1");
197
&add ("ebx", "\$_GLOBAL_OFFSET_TABLE_+[.-" . &label("pic_point1") . "]");
198
&call("$enc_func\@PLT");
200
&mov("eax", &DWP($data_off,"esp","",0));
201
&mov("ebx", &DWP($data_off+4,"esp","",0));
203
&bswap("eax") if $swap;
204
&bswap("ebx") if $swap;
206
&mov(&DWP(0,$out,"",0),"eax");
207
&mov(&DWP(4,$out,"",0),"ebx");
209
&jmp(&label("finish"));
211
#############################################################
212
#############################################################
213
&set_label("decrypt",1);
215
&and($count,0xfffffff8);
216
# The next 2 instructions are only for if the jz is taken
217
&mov("eax", &DWP($data_off+8,"esp","",0)); # get iv[0]
218
&mov("ebx", &DWP($data_off+12,"esp","",0)); # get iv[1]
219
&jz(&label("decrypt_finish"));
221
&set_label("decrypt_loop");
222
&mov("eax", &DWP(0,$in,"",0)); # load first 4 bytes
223
&mov("ebx", &DWP(4,$in,"",0)); # second 4 bytes
225
&bswap("eax") if $swap;
226
&bswap("ebx") if $swap;
228
&mov(&DWP($data_off,"esp","",0), "eax"); # put back
229
&mov(&DWP($data_off+4,"esp","",0), "ebx"); #
231
&call (&label("pic_point2"));
232
&set_label("pic_point2");
234
&add ("ebx", "\$_GLOBAL_OFFSET_TABLE_+[.-" . &label("pic_point2") . "]");
235
&call("$dec_func\@PLT");
237
&mov("eax", &DWP($data_off,"esp","",0)); # get return
238
&mov("ebx", &DWP($data_off+4,"esp","",0)); #
240
&bswap("eax") if $swap;
241
&bswap("ebx") if $swap;
243
&mov("ecx", &DWP($data_off+8,"esp","",0)); # get iv[0]
244
&mov("edx", &DWP($data_off+12,"esp","",0)); # get iv[1]
249
&mov("eax", &DWP(0,$in,"",0)); # get old cipher text,
250
&mov("ebx", &DWP(4,$in,"",0)); # next iv actually
252
&mov(&DWP(0,$out,"",0),"ecx");
253
&mov(&DWP(4,$out,"",0),"edx");
255
&mov(&DWP($data_off+8,"esp","",0), "eax"); # save iv
256
&mov(&DWP($data_off+12,"esp","",0), "ebx"); #
262
&jnz(&label("decrypt_loop"));
263
############################ ENDIT #######################3
264
&set_label("decrypt_finish");
265
&mov($count, &wparam(2)); # length
267
&jz(&label("finish"));
269
&mov("eax", &DWP(0,$in,"",0)); # load first 4 bytes
270
&mov("ebx", &DWP(4,$in,"",0)); # second 4 bytes
272
&bswap("eax") if $swap;
273
&bswap("ebx") if $swap;
275
&mov(&DWP($data_off,"esp","",0), "eax"); # put back
276
&mov(&DWP($data_off+4,"esp","",0), "ebx"); #
278
&call (&label("pic_point3"));
279
&set_label("pic_point3");
281
&add ("ebx", "\$_GLOBAL_OFFSET_TABLE_+[.-" . &label("pic_point3") . "]");
282
&call("$dec_func\@PLT");
284
&mov("eax", &DWP($data_off,"esp","",0)); # get return
285
&mov("ebx", &DWP($data_off+4,"esp","",0)); #
287
&bswap("eax") if $swap;
288
&bswap("ebx") if $swap;
290
&mov("ecx", &DWP($data_off+8,"esp","",0)); # get iv[0]
291
&mov("edx", &DWP($data_off+12,"esp","",0)); # get iv[1]
296
# this is for when we exit
297
&mov("eax", &DWP(0,$in,"",0)); # get old cipher text,
298
&mov("ebx", &DWP(4,$in,"",0)); # next iv actually
302
&movb(&BP(6,$out,"",0), &LB("edx"));
305
&movb(&BP(5,$out,"",0), &HB("edx"));
307
&movb(&BP(4,$out,"",0), &LB("edx"));
309
&mov(&DWP(0,$out,"",0), "ecx");
310
&jmp(&label("djend"));
313
&movb(&BP(2,$out,"",0), &LB("ecx"));
316
&movb(&BP(1,$in,"",0), &HB("ecx"));
318
&movb(&BP(0,$in,"",0), &LB("ecx"));
321
# final iv is still in eax:ebx
322
&jmp(&label("finish"));
325
############################ FINISH #######################3
326
&set_label("finish",1);
327
&mov("ecx", &wparam($iv_off)); # Get iv ptr
329
#################################################
331
$total+=4 if ($p1 > 0);
332
$total+=4 if ($p2 > 0);
333
$total+=4 if ($p3 > 0);
336
&mov(&DWP(0,"ecx","",0), "eax"); # save iv
337
&mov(&DWP(4,"ecx","",0), "ebx"); # save iv
339
&function_end_A($name);
342
&set_label("cbc_enc_jmp_table");
344
&data_word(&label("ej1")."-".&label("PIC_point"));
345
&data_word(&label("ej2")."-".&label("PIC_point"));
346
&data_word(&label("ej3")."-".&label("PIC_point"));
347
&data_word(&label("ej4")."-".&label("PIC_point"));
348
&data_word(&label("ej5")."-".&label("PIC_point"));
349
&data_word(&label("ej6")."-".&label("PIC_point"));
350
&data_word(&label("ej7")."-".&label("PIC_point"));
352
#&set_label("cbc_dec_jmp_table",1);
354
#&data_word(&label("dj1")."-".&label("PIC_point"));
355
#&data_word(&label("dj2")."-".&label("PIC_point"));
356
#&data_word(&label("dj3")."-".&label("PIC_point"));
357
#&data_word(&label("dj4")."-".&label("PIC_point"));
358
#&data_word(&label("dj5")."-".&label("PIC_point"));
359
#&data_word(&label("dj6")."-".&label("PIC_point"));
360
#&data_word(&label("dj7")."-".&label("PIC_point"));
363
&function_end_B($name);