| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710 |
- %ifidn __OUTPUT_FORMAT__,obj
- section code use32 class=code align=256
- %elifidn __OUTPUT_FORMAT__,win32
- [email protected] equ 1
- section .text code align=256
- %else
- section .text code
- %endif
- align 16
- __x86_AES_encrypt_compact:
- mov DWORD [20+esp],edi
- xor eax,DWORD [edi]
- xor ebx,DWORD [4+edi]
- xor ecx,DWORD [8+edi]
- xor edx,DWORD [12+edi]
- mov esi,DWORD [240+edi]
- lea esi,[esi*1+esi-2]
- lea esi,[esi*8+edi]
- mov DWORD [24+esp],esi
- mov edi,DWORD [ebp-128]
- mov esi,DWORD [ebp-96]
- mov edi,DWORD [ebp-64]
- mov esi,DWORD [ebp-32]
- mov edi,DWORD [ebp]
- mov esi,DWORD [32+ebp]
- mov edi,DWORD [64+ebp]
- mov esi,DWORD [96+ebp]
- align 16
- L$000loop:
- mov esi,eax
- and esi,255
- movzx esi,BYTE [esi*1+ebp-128]
- movzx edi,bh
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,8
- xor esi,edi
- mov edi,ecx
- shr edi,16
- and edi,255
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,16
- xor esi,edi
- mov edi,edx
- shr edi,24
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,24
- xor esi,edi
- mov DWORD [4+esp],esi
- mov esi,ebx
- and esi,255
- shr ebx,16
- movzx esi,BYTE [esi*1+ebp-128]
- movzx edi,ch
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,8
- xor esi,edi
- mov edi,edx
- shr edi,16
- and edi,255
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,16
- xor esi,edi
- mov edi,eax
- shr edi,24
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,24
- xor esi,edi
- mov DWORD [8+esp],esi
- mov esi,ecx
- and esi,255
- shr ecx,24
- movzx esi,BYTE [esi*1+ebp-128]
- movzx edi,dh
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,8
- xor esi,edi
- mov edi,eax
- shr edi,16
- and edx,255
- and edi,255
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,16
- xor esi,edi
- movzx edi,bh
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,24
- xor esi,edi
- and edx,255
- movzx edx,BYTE [edx*1+ebp-128]
- movzx eax,ah
- movzx eax,BYTE [eax*1+ebp-128]
- shl eax,8
- xor edx,eax
- mov eax,DWORD [4+esp]
- and ebx,255
- movzx ebx,BYTE [ebx*1+ebp-128]
- shl ebx,16
- xor edx,ebx
- mov ebx,DWORD [8+esp]
- movzx ecx,BYTE [ecx*1+ebp-128]
- shl ecx,24
- xor edx,ecx
- mov ecx,esi
- mov ebp,2155905152
- and ebp,ecx
- lea edi,[ecx*1+ecx]
- mov esi,ebp
- shr ebp,7
- and edi,4278124286
- sub esi,ebp
- mov ebp,ecx
- and esi,454761243
- ror ebp,16
- xor esi,edi
- mov edi,ecx
- xor ecx,esi
- ror edi,24
- xor esi,ebp
- rol ecx,24
- xor esi,edi
- mov ebp,2155905152
- xor ecx,esi
- and ebp,edx
- lea edi,[edx*1+edx]
- mov esi,ebp
- shr ebp,7
- and edi,4278124286
- sub esi,ebp
- mov ebp,edx
- and esi,454761243
- ror ebp,16
- xor esi,edi
- mov edi,edx
- xor edx,esi
- ror edi,24
- xor esi,ebp
- rol edx,24
- xor esi,edi
- mov ebp,2155905152
- xor edx,esi
- and ebp,eax
- lea edi,[eax*1+eax]
- mov esi,ebp
- shr ebp,7
- and edi,4278124286
- sub esi,ebp
- mov ebp,eax
- and esi,454761243
- ror ebp,16
- xor esi,edi
- mov edi,eax
- xor eax,esi
- ror edi,24
- xor esi,ebp
- rol eax,24
- xor esi,edi
- mov ebp,2155905152
- xor eax,esi
- and ebp,ebx
- lea edi,[ebx*1+ebx]
- mov esi,ebp
- shr ebp,7
- and edi,4278124286
- sub esi,ebp
- mov ebp,ebx
- and esi,454761243
- ror ebp,16
- xor esi,edi
- mov edi,ebx
- xor ebx,esi
- ror edi,24
- xor esi,ebp
- rol ebx,24
- xor esi,edi
- xor ebx,esi
- mov edi,DWORD [20+esp]
- mov ebp,DWORD [28+esp]
- add edi,16
- xor eax,DWORD [edi]
- xor ebx,DWORD [4+edi]
- xor ecx,DWORD [8+edi]
- xor edx,DWORD [12+edi]
- cmp edi,DWORD [24+esp]
- mov DWORD [20+esp],edi
- jb NEAR L$000loop
- mov esi,eax
- and esi,255
- movzx esi,BYTE [esi*1+ebp-128]
- movzx edi,bh
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,8
- xor esi,edi
- mov edi,ecx
- shr edi,16
- and edi,255
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,16
- xor esi,edi
- mov edi,edx
- shr edi,24
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,24
- xor esi,edi
- mov DWORD [4+esp],esi
- mov esi,ebx
- and esi,255
- shr ebx,16
- movzx esi,BYTE [esi*1+ebp-128]
- movzx edi,ch
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,8
- xor esi,edi
- mov edi,edx
- shr edi,16
- and edi,255
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,16
- xor esi,edi
- mov edi,eax
- shr edi,24
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,24
- xor esi,edi
- mov DWORD [8+esp],esi
- mov esi,ecx
- and esi,255
- shr ecx,24
- movzx esi,BYTE [esi*1+ebp-128]
- movzx edi,dh
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,8
- xor esi,edi
- mov edi,eax
- shr edi,16
- and edx,255
- and edi,255
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,16
- xor esi,edi
- movzx edi,bh
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,24
- xor esi,edi
- mov edi,DWORD [20+esp]
- and edx,255
- movzx edx,BYTE [edx*1+ebp-128]
- movzx eax,ah
- movzx eax,BYTE [eax*1+ebp-128]
- shl eax,8
- xor edx,eax
- mov eax,DWORD [4+esp]
- and ebx,255
- movzx ebx,BYTE [ebx*1+ebp-128]
- shl ebx,16
- xor edx,ebx
- mov ebx,DWORD [8+esp]
- movzx ecx,BYTE [ecx*1+ebp-128]
- shl ecx,24
- xor edx,ecx
- mov ecx,esi
- xor eax,DWORD [16+edi]
- xor ebx,DWORD [20+edi]
- xor ecx,DWORD [24+edi]
- xor edx,DWORD [28+edi]
- ret
- align 16
- __x86_AES_encrypt:
- mov DWORD [20+esp],edi
- xor eax,DWORD [edi]
- xor ebx,DWORD [4+edi]
- xor ecx,DWORD [8+edi]
- xor edx,DWORD [12+edi]
- mov esi,DWORD [240+edi]
- lea esi,[esi*1+esi-2]
- lea esi,[esi*8+edi]
- mov DWORD [24+esp],esi
- align 16
- L$001loop:
- mov esi,eax
- and esi,255
- mov esi,DWORD [esi*8+ebp]
- movzx edi,bh
- xor esi,DWORD [3+edi*8+ebp]
- mov edi,ecx
- shr edi,16
- and edi,255
- xor esi,DWORD [2+edi*8+ebp]
- mov edi,edx
- shr edi,24
- xor esi,DWORD [1+edi*8+ebp]
- mov DWORD [4+esp],esi
- mov esi,ebx
- and esi,255
- shr ebx,16
- mov esi,DWORD [esi*8+ebp]
- movzx edi,ch
- xor esi,DWORD [3+edi*8+ebp]
- mov edi,edx
- shr edi,16
- and edi,255
- xor esi,DWORD [2+edi*8+ebp]
- mov edi,eax
- shr edi,24
- xor esi,DWORD [1+edi*8+ebp]
- mov DWORD [8+esp],esi
- mov esi,ecx
- and esi,255
- shr ecx,24
- mov esi,DWORD [esi*8+ebp]
- movzx edi,dh
- xor esi,DWORD [3+edi*8+ebp]
- mov edi,eax
- shr edi,16
- and edx,255
- and edi,255
- xor esi,DWORD [2+edi*8+ebp]
- movzx edi,bh
- xor esi,DWORD [1+edi*8+ebp]
- mov edi,DWORD [20+esp]
- mov edx,DWORD [edx*8+ebp]
- movzx eax,ah
- xor edx,DWORD [3+eax*8+ebp]
- mov eax,DWORD [4+esp]
- and ebx,255
- xor edx,DWORD [2+ebx*8+ebp]
- mov ebx,DWORD [8+esp]
- xor edx,DWORD [1+ecx*8+ebp]
- mov ecx,esi
- add edi,16
- xor eax,DWORD [edi]
- xor ebx,DWORD [4+edi]
- xor ecx,DWORD [8+edi]
- xor edx,DWORD [12+edi]
- cmp edi,DWORD [24+esp]
- mov DWORD [20+esp],edi
- jb NEAR L$001loop
- mov esi,eax
- and esi,255
- mov esi,DWORD [2+esi*8+ebp]
- and esi,255
- movzx edi,bh
- mov edi,DWORD [edi*8+ebp]
- and edi,65280
- xor esi,edi
- mov edi,ecx
- shr edi,16
- and edi,255
- mov edi,DWORD [edi*8+ebp]
- and edi,16711680
- xor esi,edi
- mov edi,edx
- shr edi,24
- mov edi,DWORD [2+edi*8+ebp]
- and edi,4278190080
- xor esi,edi
- mov DWORD [4+esp],esi
- mov esi,ebx
- and esi,255
- shr ebx,16
- mov esi,DWORD [2+esi*8+ebp]
- and esi,255
- movzx edi,ch
- mov edi,DWORD [edi*8+ebp]
- and edi,65280
- xor esi,edi
- mov edi,edx
- shr edi,16
- and edi,255
- mov edi,DWORD [edi*8+ebp]
- and edi,16711680
- xor esi,edi
- mov edi,eax
- shr edi,24
- mov edi,DWORD [2+edi*8+ebp]
- and edi,4278190080
- xor esi,edi
- mov DWORD [8+esp],esi
- mov esi,ecx
- and esi,255
- shr ecx,24
- mov esi,DWORD [2+esi*8+ebp]
- and esi,255
- movzx edi,dh
- mov edi,DWORD [edi*8+ebp]
- and edi,65280
- xor esi,edi
- mov edi,eax
- shr edi,16
- and edx,255
- and edi,255
- mov edi,DWORD [edi*8+ebp]
- and edi,16711680
- xor esi,edi
- movzx edi,bh
- mov edi,DWORD [2+edi*8+ebp]
- and edi,4278190080
- xor esi,edi
- mov edi,DWORD [20+esp]
- and edx,255
- mov edx,DWORD [2+edx*8+ebp]
- and edx,255
- movzx eax,ah
- mov eax,DWORD [eax*8+ebp]
- and eax,65280
- xor edx,eax
- mov eax,DWORD [4+esp]
- and ebx,255
- mov ebx,DWORD [ebx*8+ebp]
- and ebx,16711680
- xor edx,ebx
- mov ebx,DWORD [8+esp]
- mov ecx,DWORD [2+ecx*8+ebp]
- and ecx,4278190080
- xor edx,ecx
- mov ecx,esi
- add edi,16
- xor eax,DWORD [edi]
- xor ebx,DWORD [4+edi]
- xor ecx,DWORD [8+edi]
- xor edx,DWORD [12+edi]
- ret
- align 64
- L$AES_Te:
- dd 2774754246,2774754246
- dd 2222750968,2222750968
- dd 2574743534,2574743534
- dd 2373680118,2373680118
- dd 234025727,234025727
- dd 3177933782,3177933782
- dd 2976870366,2976870366
- dd 1422247313,1422247313
- dd 1345335392,1345335392
- dd 50397442,50397442
- dd 2842126286,2842126286
- dd 2099981142,2099981142
- dd 436141799,436141799
- dd 1658312629,1658312629
- dd 3870010189,3870010189
- dd 2591454956,2591454956
- dd 1170918031,1170918031
- dd 2642575903,2642575903
- dd 1086966153,1086966153
- dd 2273148410,2273148410
- dd 368769775,368769775
- dd 3948501426,3948501426
- dd 3376891790,3376891790
- dd 200339707,200339707
- dd 3970805057,3970805057
- dd 1742001331,1742001331
- dd 4255294047,4255294047
- dd 3937382213,3937382213
- dd 3214711843,3214711843
- dd 4154762323,4154762323
- dd 2524082916,2524082916
- dd 1539358875,1539358875
- dd 3266819957,3266819957
- dd 486407649,486407649
- dd 2928907069,2928907069
- dd 1780885068,1780885068
- dd 1513502316,1513502316
- dd 1094664062,1094664062
- dd 49805301,49805301
- dd 1338821763,1338821763
- dd 1546925160,1546925160
- dd 4104496465,4104496465
- dd 887481809,887481809
- dd 150073849,150073849
- dd 2473685474,2473685474
- dd 1943591083,1943591083
- dd 1395732834,1395732834
- dd 1058346282,1058346282
- dd 201589768,201589768
- dd 1388824469,1388824469
- dd 1696801606,1696801606
- dd 1589887901,1589887901
- dd 672667696,672667696
- dd 2711000631,2711000631
- dd 251987210,251987210
- dd 3046808111,3046808111
- dd 151455502,151455502
- dd 907153956,907153956
- dd 2608889883,2608889883
- dd 1038279391,1038279391
- dd 652995533,652995533
- dd 1764173646,1764173646
- dd 3451040383,3451040383
- dd 2675275242,2675275242
- dd 453576978,453576978
- dd 2659418909,2659418909
- dd 1949051992,1949051992
- dd 773462580,773462580
- dd 756751158,756751158
- dd 2993581788,2993581788
- dd 3998898868,3998898868
- dd 4221608027,4221608027
- dd 4132590244,4132590244
- dd 1295727478,1295727478
- dd 1641469623,1641469623
- dd 3467883389,3467883389
- dd 2066295122,2066295122
- dd 1055122397,1055122397
- dd 1898917726,1898917726
- dd 2542044179,2542044179
- dd 4115878822,4115878822
- dd 1758581177,1758581177
- dd 0,0
- dd 753790401,753790401
- dd 1612718144,1612718144
- dd 536673507,536673507
- dd 3367088505,3367088505
- dd 3982187446,3982187446
- dd 3194645204,3194645204
- dd 1187761037,1187761037
- dd 3653156455,3653156455
- dd 1262041458,1262041458
- dd 3729410708,3729410708
- dd 3561770136,3561770136
- dd 3898103984,3898103984
- dd 1255133061,1255133061
- dd 1808847035,1808847035
- dd 720367557,720367557
- dd 3853167183,3853167183
- dd 385612781,385612781
- dd 3309519750,3309519750
- dd 3612167578,3612167578
- dd 1429418854,1429418854
- dd 2491778321,2491778321
- dd 3477423498,3477423498
- dd 284817897,284817897
- dd 100794884,100794884
- dd 2172616702,2172616702
- dd 4031795360,4031795360
- dd 1144798328,1144798328
- dd 3131023141,3131023141
- dd 3819481163,3819481163
- dd 4082192802,4082192802
- dd 4272137053,4272137053
- dd 3225436288,3225436288
- dd 2324664069,2324664069
- dd 2912064063,2912064063
- dd 3164445985,3164445985
- dd 1211644016,1211644016
- dd 83228145,83228145
- dd 3753688163,3753688163
- dd 3249976951,3249976951
- dd 1977277103,1977277103
- dd 1663115586,1663115586
- dd 806359072,806359072
- dd 452984805,452984805
- dd 250868733,250868733
- dd 1842533055,1842533055
- dd 1288555905,1288555905
- dd 336333848,336333848
- dd 890442534,890442534
- dd 804056259,804056259
- dd 3781124030,3781124030
- dd 2727843637,2727843637
- dd 3427026056,3427026056
- dd 957814574,957814574
- dd 1472513171,1472513171
- dd 4071073621,4071073621
- dd 2189328124,2189328124
- dd 1195195770,1195195770
- dd 2892260552,2892260552
- dd 3881655738,3881655738
- dd 723065138,723065138
- dd 2507371494,2507371494
- dd 2690670784,2690670784
- dd 2558624025,2558624025
- dd 3511635870,3511635870
- dd 2145180835,2145180835
- dd 1713513028,1713513028
- dd 2116692564,2116692564
- dd 2878378043,2878378043
- dd 2206763019,2206763019
- dd 3393603212,3393603212
- dd 703524551,703524551
- dd 3552098411,3552098411
- dd 1007948840,1007948840
- dd 2044649127,2044649127
- dd 3797835452,3797835452
- dd 487262998,487262998
- dd 1994120109,1994120109
- dd 1004593371,1004593371
- dd 1446130276,1446130276
- dd 1312438900,1312438900
- dd 503974420,503974420
- dd 3679013266,3679013266
- dd 168166924,168166924
- dd 1814307912,1814307912
- dd 3831258296,3831258296
- dd 1573044895,1573044895
- dd 1859376061,1859376061
- dd 4021070915,4021070915
- dd 2791465668,2791465668
- dd 2828112185,2828112185
- dd 2761266481,2761266481
- dd 937747667,937747667
- dd 2339994098,2339994098
- dd 854058965,854058965
- dd 1137232011,1137232011
- dd 1496790894,1496790894
- dd 3077402074,3077402074
- dd 2358086913,2358086913
- dd 1691735473,1691735473
- dd 3528347292,3528347292
- dd 3769215305,3769215305
- dd 3027004632,3027004632
- dd 4199962284,4199962284
- dd 133494003,133494003
- dd 636152527,636152527
- dd 2942657994,2942657994
- dd 2390391540,2390391540
- dd 3920539207,3920539207
- dd 403179536,403179536
- dd 3585784431,3585784431
- dd 2289596656,2289596656
- dd 1864705354,1864705354
- dd 1915629148,1915629148
- dd 605822008,605822008
- dd 4054230615,4054230615
- dd 3350508659,3350508659
- dd 1371981463,1371981463
- dd 602466507,602466507
- dd 2094914977,2094914977
- dd 2624877800,2624877800
- dd 555687742,555687742
- dd 3712699286,3712699286
- dd 3703422305,3703422305
- dd 2257292045,2257292045
- dd 2240449039,2240449039
- dd 2423288032,2423288032
- dd 1111375484,1111375484
- dd 3300242801,3300242801
- dd 2858837708,2858837708
- dd 3628615824,3628615824
- dd 84083462,84083462
- dd 32962295,32962295
- dd 302911004,302911004
- dd 2741068226,2741068226
- dd 1597322602,1597322602
- dd 4183250862,4183250862
- dd 3501832553,3501832553
- dd 2441512471,2441512471
- dd 1489093017,1489093017
- dd 656219450,656219450
- dd 3114180135,3114180135
- dd 954327513,954327513
- dd 335083755,335083755
- dd 3013122091,3013122091
- dd 856756514,856756514
- dd 3144247762,3144247762
- dd 1893325225,1893325225
- dd 2307821063,2307821063
- dd 2811532339,2811532339
- dd 3063651117,3063651117
- dd 572399164,572399164
- dd 2458355477,2458355477
- dd 552200649,552200649
- dd 1238290055,1238290055
- dd 4283782570,4283782570
- dd 2015897680,2015897680
- dd 2061492133,2061492133
- dd 2408352771,2408352771
- dd 4171342169,4171342169
- dd 2156497161,2156497161
- dd 386731290,386731290
- dd 3669999461,3669999461
- dd 837215959,837215959
- dd 3326231172,3326231172
- dd 3093850320,3093850320
- dd 3275833730,3275833730
- dd 2962856233,2962856233
- dd 1999449434,1999449434
- dd 286199582,286199582
- dd 3417354363,3417354363
- dd 4233385128,4233385128
- dd 3602627437,3602627437
- dd 974525996,974525996
- db 99,124,119,123,242,107,111,197
- db 48,1,103,43,254,215,171,118
- db 202,130,201,125,250,89,71,240
- db 173,212,162,175,156,164,114,192
- db 183,253,147,38,54,63,247,204
- db 52,165,229,241,113,216,49,21
- db 4,199,35,195,24,150,5,154
- db 7,18,128,226,235,39,178,117
- db 9,131,44,26,27,110,90,160
- db 82,59,214,179,41,227,47,132
- db 83,209,0,237,32,252,177,91
- db 106,203,190,57,74,76,88,207
- db 208,239,170,251,67,77,51,133
- db 69,249,2,127,80,60,159,168
- db 81,163,64,143,146,157,56,245
- db 188,182,218,33,16,255,243,210
- db 205,12,19,236,95,151,68,23
- db 196,167,126,61,100,93,25,115
- db 96,129,79,220,34,42,144,136
- db 70,238,184,20,222,94,11,219
- db 224,50,58,10,73,6,36,92
- db 194,211,172,98,145,149,228,121
- db 231,200,55,109,141,213,78,169
- db 108,86,244,234,101,122,174,8
- db 186,120,37,46,28,166,180,198
- db 232,221,116,31,75,189,139,138
- db 112,62,181,102,72,3,246,14
- db 97,53,87,185,134,193,29,158
- db 225,248,152,17,105,217,142,148
- db 155,30,135,233,206,85,40,223
- db 140,161,137,13,191,230,66,104
- db 65,153,45,15,176,84,187,22
- db 99,124,119,123,242,107,111,197
- db 48,1,103,43,254,215,171,118
- db 202,130,201,125,250,89,71,240
- db 173,212,162,175,156,164,114,192
- db 183,253,147,38,54,63,247,204
- db 52,165,229,241,113,216,49,21
- db 4,199,35,195,24,150,5,154
- db 7,18,128,226,235,39,178,117
- db 9,131,44,26,27,110,90,160
- db 82,59,214,179,41,227,47,132
- db 83,209,0,237,32,252,177,91
- db 106,203,190,57,74,76,88,207
- db 208,239,170,251,67,77,51,133
- db 69,249,2,127,80,60,159,168
- db 81,163,64,143,146,157,56,245
- db 188,182,218,33,16,255,243,210
- db 205,12,19,236,95,151,68,23
- db 196,167,126,61,100,93,25,115
- db 96,129,79,220,34,42,144,136
- db 70,238,184,20,222,94,11,219
- db 224,50,58,10,73,6,36,92
- db 194,211,172,98,145,149,228,121
- db 231,200,55,109,141,213,78,169
- db 108,86,244,234,101,122,174,8
- db 186,120,37,46,28,166,180,198
- db 232,221,116,31,75,189,139,138
- db 112,62,181,102,72,3,246,14
- db 97,53,87,185,134,193,29,158
- db 225,248,152,17,105,217,142,148
- db 155,30,135,233,206,85,40,223
- db 140,161,137,13,191,230,66,104
- db 65,153,45,15,176,84,187,22
- db 99,124,119,123,242,107,111,197
- db 48,1,103,43,254,215,171,118
- db 202,130,201,125,250,89,71,240
- db 173,212,162,175,156,164,114,192
- db 183,253,147,38,54,63,247,204
- db 52,165,229,241,113,216,49,21
- db 4,199,35,195,24,150,5,154
- db 7,18,128,226,235,39,178,117
- db 9,131,44,26,27,110,90,160
- db 82,59,214,179,41,227,47,132
- db 83,209,0,237,32,252,177,91
- db 106,203,190,57,74,76,88,207
- db 208,239,170,251,67,77,51,133
- db 69,249,2,127,80,60,159,168
- db 81,163,64,143,146,157,56,245
- db 188,182,218,33,16,255,243,210
- db 205,12,19,236,95,151,68,23
- db 196,167,126,61,100,93,25,115
- db 96,129,79,220,34,42,144,136
- db 70,238,184,20,222,94,11,219
- db 224,50,58,10,73,6,36,92
- db 194,211,172,98,145,149,228,121
- db 231,200,55,109,141,213,78,169
- db 108,86,244,234,101,122,174,8
- db 186,120,37,46,28,166,180,198
- db 232,221,116,31,75,189,139,138
- db 112,62,181,102,72,3,246,14
- db 97,53,87,185,134,193,29,158
- db 225,248,152,17,105,217,142,148
- db 155,30,135,233,206,85,40,223
- db 140,161,137,13,191,230,66,104
- db 65,153,45,15,176,84,187,22
- db 99,124,119,123,242,107,111,197
- db 48,1,103,43,254,215,171,118
- db 202,130,201,125,250,89,71,240
- db 173,212,162,175,156,164,114,192
- db 183,253,147,38,54,63,247,204
- db 52,165,229,241,113,216,49,21
- db 4,199,35,195,24,150,5,154
- db 7,18,128,226,235,39,178,117
- db 9,131,44,26,27,110,90,160
- db 82,59,214,179,41,227,47,132
- db 83,209,0,237,32,252,177,91
- db 106,203,190,57,74,76,88,207
- db 208,239,170,251,67,77,51,133
- db 69,249,2,127,80,60,159,168
- db 81,163,64,143,146,157,56,245
- db 188,182,218,33,16,255,243,210
- db 205,12,19,236,95,151,68,23
- db 196,167,126,61,100,93,25,115
- db 96,129,79,220,34,42,144,136
- db 70,238,184,20,222,94,11,219
- db 224,50,58,10,73,6,36,92
- db 194,211,172,98,145,149,228,121
- db 231,200,55,109,141,213,78,169
- db 108,86,244,234,101,122,174,8
- db 186,120,37,46,28,166,180,198
- db 232,221,116,31,75,189,139,138
- db 112,62,181,102,72,3,246,14
- db 97,53,87,185,134,193,29,158
- db 225,248,152,17,105,217,142,148
- db 155,30,135,233,206,85,40,223
- db 140,161,137,13,191,230,66,104
- db 65,153,45,15,176,84,187,22
- dd 1,2,4,8
- dd 16,32,64,128
- dd 27,54,0,0
- dd 0,0,0,0
- global _AES_encrypt
- align 16
- _AES_encrypt:
- L$_AES_encrypt_begin:
- push ebp
- push ebx
- push esi
- push edi
- mov esi,DWORD [20+esp]
- mov edi,DWORD [28+esp]
- mov eax,esp
- sub esp,36
- and esp,-64
- lea ebx,[edi-127]
- sub ebx,esp
- neg ebx
- and ebx,960
- sub esp,ebx
- add esp,4
- mov DWORD [28+esp],eax
- call L$002pic_point
- L$002pic_point:
- pop ebp
- lea ebp,[(L$AES_Te-L$002pic_point)+ebp]
- lea ebx,[764+esp]
- sub ebx,ebp
- and ebx,768
- lea ebp,[2176+ebx*1+ebp]
- align 16
- L$003x86:
- mov DWORD [24+esp],ebp
- mov eax,DWORD [esi]
- mov ebx,DWORD [4+esi]
- mov ecx,DWORD [8+esi]
- mov edx,DWORD [12+esi]
- call __x86_AES_encrypt_compact
- mov esp,DWORD [28+esp]
- mov esi,DWORD [24+esp]
- mov DWORD [esi],eax
- mov DWORD [4+esi],ebx
- mov DWORD [8+esi],ecx
- mov DWORD [12+esi],edx
- pop edi
- pop esi
- pop ebx
- pop ebp
- ret
- align 16
- __x86_AES_decrypt_compact:
- mov DWORD [20+esp],edi
- xor eax,DWORD [edi]
- xor ebx,DWORD [4+edi]
- xor ecx,DWORD [8+edi]
- xor edx,DWORD [12+edi]
- mov esi,DWORD [240+edi]
- lea esi,[esi*1+esi-2]
- lea esi,[esi*8+edi]
- mov DWORD [24+esp],esi
- mov edi,DWORD [ebp-128]
- mov esi,DWORD [ebp-96]
- mov edi,DWORD [ebp-64]
- mov esi,DWORD [ebp-32]
- mov edi,DWORD [ebp]
- mov esi,DWORD [32+ebp]
- mov edi,DWORD [64+ebp]
- mov esi,DWORD [96+ebp]
- align 16
- L$004loop:
- mov esi,eax
- and esi,255
- movzx esi,BYTE [esi*1+ebp-128]
- movzx edi,dh
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,8
- xor esi,edi
- mov edi,ecx
- shr edi,16
- and edi,255
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,16
- xor esi,edi
- mov edi,ebx
- shr edi,24
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,24
- xor esi,edi
- mov DWORD [4+esp],esi
- mov esi,ebx
- and esi,255
- movzx esi,BYTE [esi*1+ebp-128]
- movzx edi,ah
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,8
- xor esi,edi
- mov edi,edx
- shr edi,16
- and edi,255
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,16
- xor esi,edi
- mov edi,ecx
- shr edi,24
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,24
- xor esi,edi
- mov DWORD [8+esp],esi
- mov esi,ecx
- and esi,255
- movzx esi,BYTE [esi*1+ebp-128]
- movzx edi,bh
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,8
- xor esi,edi
- mov edi,eax
- shr edi,16
- and edi,255
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,16
- xor esi,edi
- mov edi,edx
- shr edi,24
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,24
- xor esi,edi
- and edx,255
- movzx edx,BYTE [edx*1+ebp-128]
- movzx ecx,ch
- movzx ecx,BYTE [ecx*1+ebp-128]
- shl ecx,8
- xor edx,ecx
- mov ecx,esi
- shr ebx,16
- and ebx,255
- movzx ebx,BYTE [ebx*1+ebp-128]
- shl ebx,16
- xor edx,ebx
- shr eax,24
- movzx eax,BYTE [eax*1+ebp-128]
- shl eax,24
- xor edx,eax
- mov edi,2155905152
- and edi,ecx
- mov esi,edi
- shr edi,7
- lea eax,[ecx*1+ecx]
- sub esi,edi
- and eax,4278124286
- and esi,454761243
- xor eax,esi
- mov edi,2155905152
- and edi,eax
- mov esi,edi
- shr edi,7
- lea ebx,[eax*1+eax]
- sub esi,edi
- and ebx,4278124286
- and esi,454761243
- xor eax,ecx
- xor ebx,esi
- mov edi,2155905152
- and edi,ebx
- mov esi,edi
- shr edi,7
- lea ebp,[ebx*1+ebx]
- sub esi,edi
- and ebp,4278124286
- and esi,454761243
- xor ebx,ecx
- rol ecx,8
- xor ebp,esi
- xor ecx,eax
- xor eax,ebp
- xor ecx,ebx
- xor ebx,ebp
- rol eax,24
- xor ecx,ebp
- rol ebx,16
- xor ecx,eax
- rol ebp,8
- xor ecx,ebx
- mov eax,DWORD [4+esp]
- xor ecx,ebp
- mov DWORD [12+esp],ecx
- mov edi,2155905152
- and edi,edx
- mov esi,edi
- shr edi,7
- lea ebx,[edx*1+edx]
- sub esi,edi
- and ebx,4278124286
- and esi,454761243
- xor ebx,esi
- mov edi,2155905152
- and edi,ebx
- mov esi,edi
- shr edi,7
- lea ecx,[ebx*1+ebx]
- sub esi,edi
- and ecx,4278124286
- and esi,454761243
- xor ebx,edx
- xor ecx,esi
- mov edi,2155905152
- and edi,ecx
- mov esi,edi
- shr edi,7
- lea ebp,[ecx*1+ecx]
- sub esi,edi
- and ebp,4278124286
- and esi,454761243
- xor ecx,edx
- rol edx,8
- xor ebp,esi
- xor edx,ebx
- xor ebx,ebp
- xor edx,ecx
- xor ecx,ebp
- rol ebx,24
- xor edx,ebp
- rol ecx,16
- xor edx,ebx
- rol ebp,8
- xor edx,ecx
- mov ebx,DWORD [8+esp]
- xor edx,ebp
- mov DWORD [16+esp],edx
- mov edi,2155905152
- and edi,eax
- mov esi,edi
- shr edi,7
- lea ecx,[eax*1+eax]
- sub esi,edi
- and ecx,4278124286
- and esi,454761243
- xor ecx,esi
- mov edi,2155905152
- and edi,ecx
- mov esi,edi
- shr edi,7
- lea edx,[ecx*1+ecx]
- sub esi,edi
- and edx,4278124286
- and esi,454761243
- xor ecx,eax
- xor edx,esi
- mov edi,2155905152
- and edi,edx
- mov esi,edi
- shr edi,7
- lea ebp,[edx*1+edx]
- sub esi,edi
- and ebp,4278124286
- and esi,454761243
- xor edx,eax
- rol eax,8
- xor ebp,esi
- xor eax,ecx
- xor ecx,ebp
- xor eax,edx
- xor edx,ebp
- rol ecx,24
- xor eax,ebp
- rol edx,16
- xor eax,ecx
- rol ebp,8
- xor eax,edx
- xor eax,ebp
- mov edi,2155905152
- and edi,ebx
- mov esi,edi
- shr edi,7
- lea ecx,[ebx*1+ebx]
- sub esi,edi
- and ecx,4278124286
- and esi,454761243
- xor ecx,esi
- mov edi,2155905152
- and edi,ecx
- mov esi,edi
- shr edi,7
- lea edx,[ecx*1+ecx]
- sub esi,edi
- and edx,4278124286
- and esi,454761243
- xor ecx,ebx
- xor edx,esi
- mov edi,2155905152
- and edi,edx
- mov esi,edi
- shr edi,7
- lea ebp,[edx*1+edx]
- sub esi,edi
- and ebp,4278124286
- and esi,454761243
- xor edx,ebx
- rol ebx,8
- xor ebp,esi
- xor ebx,ecx
- xor ecx,ebp
- xor ebx,edx
- xor edx,ebp
- rol ecx,24
- xor ebx,ebp
- rol edx,16
- xor ebx,ecx
- rol ebp,8
- xor ebx,edx
- mov ecx,DWORD [12+esp]
- xor ebx,ebp
- mov edx,DWORD [16+esp]
- mov edi,DWORD [20+esp]
- mov ebp,DWORD [28+esp]
- add edi,16
- xor eax,DWORD [edi]
- xor ebx,DWORD [4+edi]
- xor ecx,DWORD [8+edi]
- xor edx,DWORD [12+edi]
- cmp edi,DWORD [24+esp]
- mov DWORD [20+esp],edi
- jb NEAR L$004loop
- mov esi,eax
- and esi,255
- movzx esi,BYTE [esi*1+ebp-128]
- movzx edi,dh
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,8
- xor esi,edi
- mov edi,ecx
- shr edi,16
- and edi,255
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,16
- xor esi,edi
- mov edi,ebx
- shr edi,24
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,24
- xor esi,edi
- mov DWORD [4+esp],esi
- mov esi,ebx
- and esi,255
- movzx esi,BYTE [esi*1+ebp-128]
- movzx edi,ah
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,8
- xor esi,edi
- mov edi,edx
- shr edi,16
- and edi,255
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,16
- xor esi,edi
- mov edi,ecx
- shr edi,24
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,24
- xor esi,edi
- mov DWORD [8+esp],esi
- mov esi,ecx
- and esi,255
- movzx esi,BYTE [esi*1+ebp-128]
- movzx edi,bh
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,8
- xor esi,edi
- mov edi,eax
- shr edi,16
- and edi,255
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,16
- xor esi,edi
- mov edi,edx
- shr edi,24
- movzx edi,BYTE [edi*1+ebp-128]
- shl edi,24
- xor esi,edi
- mov edi,DWORD [20+esp]
- and edx,255
- movzx edx,BYTE [edx*1+ebp-128]
- movzx ecx,ch
- movzx ecx,BYTE [ecx*1+ebp-128]
- shl ecx,8
- xor edx,ecx
- mov ecx,esi
- shr ebx,16
- and ebx,255
- movzx ebx,BYTE [ebx*1+ebp-128]
- shl ebx,16
- xor edx,ebx
- mov ebx,DWORD [8+esp]
- shr eax,24
- movzx eax,BYTE [eax*1+ebp-128]
- shl eax,24
- xor edx,eax
- mov eax,DWORD [4+esp]
- xor eax,DWORD [16+edi]
- xor ebx,DWORD [20+edi]
- xor ecx,DWORD [24+edi]
- xor edx,DWORD [28+edi]
- ret
- align 16
- __x86_AES_decrypt:
- mov DWORD [20+esp],edi
- xor eax,DWORD [edi]
- xor ebx,DWORD [4+edi]
- xor ecx,DWORD [8+edi]
- xor edx,DWORD [12+edi]
- mov esi,DWORD [240+edi]
- lea esi,[esi*1+esi-2]
- lea esi,[esi*8+edi]
- mov DWORD [24+esp],esi
- align 16
- L$005loop:
- mov esi,eax
- and esi,255
- mov esi,DWORD [esi*8+ebp]
- movzx edi,dh
- xor esi,DWORD [3+edi*8+ebp]
- mov edi,ecx
- shr edi,16
- and edi,255
- xor esi,DWORD [2+edi*8+ebp]
- mov edi,ebx
- shr edi,24
- xor esi,DWORD [1+edi*8+ebp]
- mov DWORD [4+esp],esi
- mov esi,ebx
- and esi,255
- mov esi,DWORD [esi*8+ebp]
- movzx edi,ah
- xor esi,DWORD [3+edi*8+ebp]
- mov edi,edx
- shr edi,16
- and edi,255
- xor esi,DWORD [2+edi*8+ebp]
- mov edi,ecx
- shr edi,24
- xor esi,DWORD [1+edi*8+ebp]
- mov DWORD [8+esp],esi
- mov esi,ecx
- and esi,255
- mov esi,DWORD [esi*8+ebp]
- movzx edi,bh
- xor esi,DWORD [3+edi*8+ebp]
- mov edi,eax
- shr edi,16
- and edi,255
- xor esi,DWORD [2+edi*8+ebp]
- mov edi,edx
- shr edi,24
- xor esi,DWORD [1+edi*8+ebp]
- mov edi,DWORD [20+esp]
- and edx,255
- mov edx,DWORD [edx*8+ebp]
- movzx ecx,ch
- xor edx,DWORD [3+ecx*8+ebp]
- mov ecx,esi
- shr ebx,16
- and ebx,255
- xor edx,DWORD [2+ebx*8+ebp]
- mov ebx,DWORD [8+esp]
- shr eax,24
- xor edx,DWORD [1+eax*8+ebp]
- mov eax,DWORD [4+esp]
- add edi,16
- xor eax,DWORD [edi]
- xor ebx,DWORD [4+edi]
- xor ecx,DWORD [8+edi]
- xor edx,DWORD [12+edi]
- cmp edi,DWORD [24+esp]
- mov DWORD [20+esp],edi
- jb NEAR L$005loop
- lea ebp,[2176+ebp]
- mov edi,DWORD [ebp-128]
- mov esi,DWORD [ebp-96]
- mov edi,DWORD [ebp-64]
- mov esi,DWORD [ebp-32]
- mov edi,DWORD [ebp]
- mov esi,DWORD [32+ebp]
- mov edi,DWORD [64+ebp]
- mov esi,DWORD [96+ebp]
- lea ebp,[ebp-128]
- mov esi,eax
- and esi,255
- movzx esi,BYTE [esi*1+ebp]
- movzx edi,dh
- movzx edi,BYTE [edi*1+ebp]
- shl edi,8
- xor esi,edi
- mov edi,ecx
- shr edi,16
- and edi,255
- movzx edi,BYTE [edi*1+ebp]
- shl edi,16
- xor esi,edi
- mov edi,ebx
- shr edi,24
- movzx edi,BYTE [edi*1+ebp]
- shl edi,24
- xor esi,edi
- mov DWORD [4+esp],esi
- mov esi,ebx
- and esi,255
- movzx esi,BYTE [esi*1+ebp]
- movzx edi,ah
- movzx edi,BYTE [edi*1+ebp]
- shl edi,8
- xor esi,edi
- mov edi,edx
- shr edi,16
- and edi,255
- movzx edi,BYTE [edi*1+ebp]
- shl edi,16
- xor esi,edi
- mov edi,ecx
- shr edi,24
- movzx edi,BYTE [edi*1+ebp]
- shl edi,24
- xor esi,edi
- mov DWORD [8+esp],esi
- mov esi,ecx
- and esi,255
- movzx esi,BYTE [esi*1+ebp]
- movzx edi,bh
- movzx edi,BYTE [edi*1+ebp]
- shl edi,8
- xor esi,edi
- mov edi,eax
- shr edi,16
- and edi,255
- movzx edi,BYTE [edi*1+ebp]
- shl edi,16
- xor esi,edi
- mov edi,edx
- shr edi,24
- movzx edi,BYTE [edi*1+ebp]
- shl edi,24
- xor esi,edi
- mov edi,DWORD [20+esp]
- and edx,255
- movzx edx,BYTE [edx*1+ebp]
- movzx ecx,ch
- movzx ecx,BYTE [ecx*1+ebp]
- shl ecx,8
- xor edx,ecx
- mov ecx,esi
- shr ebx,16
- and ebx,255
- movzx ebx,BYTE [ebx*1+ebp]
- shl ebx,16
- xor edx,ebx
- mov ebx,DWORD [8+esp]
- shr eax,24
- movzx eax,BYTE [eax*1+ebp]
- shl eax,24
- xor edx,eax
- mov eax,DWORD [4+esp]
- lea ebp,[ebp-2048]
- add edi,16
- xor eax,DWORD [edi]
- xor ebx,DWORD [4+edi]
- xor ecx,DWORD [8+edi]
- xor edx,DWORD [12+edi]
- ret
- align 64
- L$AES_Td:
- dd 1353184337,1353184337
- dd 1399144830,1399144830
- dd 3282310938,3282310938
- dd 2522752826,2522752826
- dd 3412831035,3412831035
- dd 4047871263,4047871263
- dd 2874735276,2874735276
- dd 2466505547,2466505547
- dd 1442459680,1442459680
- dd 4134368941,4134368941
- dd 2440481928,2440481928
- dd 625738485,625738485
- dd 4242007375,4242007375
- dd 3620416197,3620416197
- dd 2151953702,2151953702
- dd 2409849525,2409849525
- dd 1230680542,1230680542
- dd 1729870373,1729870373
- dd 2551114309,2551114309
- dd 3787521629,3787521629
- dd 41234371,41234371
- dd 317738113,317738113
- dd 2744600205,2744600205
- dd 3338261355,3338261355
- dd 3881799427,3881799427
- dd 2510066197,2510066197
- dd 3950669247,3950669247
- dd 3663286933,3663286933
- dd 763608788,763608788
- dd 3542185048,3542185048
- dd 694804553,694804553
- dd 1154009486,1154009486
- dd 1787413109,1787413109
- dd 2021232372,2021232372
- dd 1799248025,1799248025
- dd 3715217703,3715217703
- dd 3058688446,3058688446
- dd 397248752,397248752
- dd 1722556617,1722556617
- dd 3023752829,3023752829
- dd 407560035,407560035
- dd 2184256229,2184256229
- dd 1613975959,1613975959
- dd 1165972322,1165972322
- dd 3765920945,3765920945
- dd 2226023355,2226023355
- dd 480281086,480281086
- dd 2485848313,2485848313
- dd 1483229296,1483229296
- dd 436028815,436028815
- dd 2272059028,2272059028
- dd 3086515026,3086515026
- dd 601060267,601060267
- dd 3791801202,3791801202
- dd 1468997603,1468997603
- dd 715871590,715871590
- dd 120122290,120122290
- dd 63092015,63092015
- dd 2591802758,2591802758
- dd 2768779219,2768779219
- dd 4068943920,4068943920
- dd 2997206819,2997206819
- dd 3127509762,3127509762
- dd 1552029421,1552029421
- dd 723308426,723308426
- dd 2461301159,2461301159
- dd 4042393587,4042393587
- dd 2715969870,2715969870
- dd 3455375973,3455375973
- dd 3586000134,3586000134
- dd 526529745,526529745
- dd 2331944644,2331944644
- dd 2639474228,2639474228
- dd 2689987490,2689987490
- dd 853641733,853641733
- dd 1978398372,1978398372
- dd 971801355,971801355
- dd 2867814464,2867814464
- dd 111112542,111112542
- dd 1360031421,1360031421
- dd 4186579262,4186579262
- dd 1023860118,1023860118
- dd 2919579357,2919579357
- dd 1186850381,1186850381
- dd 3045938321,3045938321
- dd 90031217,90031217
- dd 1876166148,1876166148
- dd 4279586912,4279586912
- dd 620468249,620468249
- dd 2548678102,2548678102
- dd 3426959497,3426959497
- dd 2006899047,2006899047
- dd 3175278768,3175278768
- dd 2290845959,2290845959
- dd 945494503,945494503
- dd 3689859193,3689859193
- dd 1191869601,1191869601
- dd 3910091388,3910091388
- dd 3374220536,3374220536
- dd 0,0
- dd 2206629897,2206629897
- dd 1223502642,1223502642
- dd 2893025566,2893025566
- dd 1316117100,1316117100
- dd 4227796733,4227796733
- dd 1446544655,1446544655
- dd 517320253,517320253
- dd 658058550,658058550
- dd 1691946762,1691946762
- dd 564550760,564550760
- dd 3511966619,3511966619
- dd 976107044,976107044
- dd 2976320012,2976320012
- dd 266819475,266819475
- dd 3533106868,3533106868
- dd 2660342555,2660342555
- dd 1338359936,1338359936
- dd 2720062561,2720062561
- dd 1766553434,1766553434
- dd 370807324,370807324
- dd 179999714,179999714
- dd 3844776128,3844776128
- dd 1138762300,1138762300
- dd 488053522,488053522
- dd 185403662,185403662
- dd 2915535858,2915535858
- dd 3114841645,3114841645
- dd 3366526484,3366526484
- dd 2233069911,2233069911
- dd 1275557295,1275557295
- dd 3151862254,3151862254
- dd 4250959779,4250959779
- dd 2670068215,2670068215
- dd 3170202204,3170202204
- dd 3309004356,3309004356
- dd 880737115,880737115
- dd 1982415755,1982415755
- dd 3703972811,3703972811
- dd 1761406390,1761406390
- dd 1676797112,1676797112
- dd 3403428311,3403428311
- dd 277177154,277177154
- dd 1076008723,1076008723
- dd 538035844,538035844
- dd 2099530373,2099530373
- dd 4164795346,4164795346
- dd 288553390,288553390
- dd 1839278535,1839278535
- dd 1261411869,1261411869
- dd 4080055004,4080055004
- dd 3964831245,3964831245
- dd 3504587127,3504587127
- dd 1813426987,1813426987
- dd 2579067049,2579067049
- dd 4199060497,4199060497
- dd 577038663,577038663
- dd 3297574056,3297574056
- dd 440397984,440397984
- dd 3626794326,3626794326
- dd 4019204898,4019204898
- dd 3343796615,3343796615
- dd 3251714265,3251714265
- dd 4272081548,4272081548
- dd 906744984,906744984
- dd 3481400742,3481400742
- dd 685669029,685669029
- dd 646887386,646887386
- dd 2764025151,2764025151
- dd 3835509292,3835509292
- dd 227702864,227702864
- dd 2613862250,2613862250
- dd 1648787028,1648787028
- dd 3256061430,3256061430
- dd 3904428176,3904428176
- dd 1593260334,1593260334
- dd 4121936770,4121936770
- dd 3196083615,3196083615
- dd 2090061929,2090061929
- dd 2838353263,2838353263
- dd 3004310991,3004310991
- dd 999926984,999926984
- dd 2809993232,2809993232
- dd 1852021992,1852021992
- dd 2075868123,2075868123
- dd 158869197,158869197
- dd 4095236462,4095236462
- dd 28809964,28809964
- dd 2828685187,2828685187
- dd 1701746150,1701746150
- dd 2129067946,2129067946
- dd 147831841,147831841
- dd 3873969647,3873969647
- dd 3650873274,3650873274
- dd 3459673930,3459673930
- dd 3557400554,3557400554
- dd 3598495785,3598495785
- dd 2947720241,2947720241
- dd 824393514,824393514
- dd 815048134,815048134
- dd 3227951669,3227951669
- dd 935087732,935087732
- dd 2798289660,2798289660
- dd 2966458592,2966458592
- dd 366520115,366520115
- dd 1251476721,1251476721
- dd 4158319681,4158319681
- dd 240176511,240176511
- dd 804688151,804688151
- dd 2379631990,2379631990
- dd 1303441219,1303441219
- dd 1414376140,1414376140
- dd 3741619940,3741619940
- dd 3820343710,3820343710
- dd 461924940,461924940
- dd 3089050817,3089050817
- dd 2136040774,2136040774
- dd 82468509,82468509
- dd 1563790337,1563790337
- dd 1937016826,1937016826
- dd 776014843,776014843
- dd 1511876531,1511876531
- dd 1389550482,1389550482
- dd 861278441,861278441
- dd 323475053,323475053
- dd 2355222426,2355222426
- dd 2047648055,2047648055
- dd 2383738969,2383738969
- dd 2302415851,2302415851
- dd 3995576782,3995576782
- dd 902390199,902390199
- dd 3991215329,3991215329
- dd 1018251130,1018251130
- dd 1507840668,1507840668
- dd 1064563285,1064563285
- dd 2043548696,2043548696
- dd 3208103795,3208103795
- dd 3939366739,3939366739
- dd 1537932639,1537932639
- dd 342834655,342834655
- dd 2262516856,2262516856
- dd 2180231114,2180231114
- dd 1053059257,1053059257
- dd 741614648,741614648
- dd 1598071746,1598071746
- dd 1925389590,1925389590
- dd 203809468,203809468
- dd 2336832552,2336832552
- dd 1100287487,1100287487
- dd 1895934009,1895934009
- dd 3736275976,3736275976
- dd 2632234200,2632234200
- dd 2428589668,2428589668
- dd 1636092795,1636092795
- dd 1890988757,1890988757
- dd 1952214088,1952214088
- dd 1113045200,1113045200
- db 82,9,106,213,48,54,165,56
- db 191,64,163,158,129,243,215,251
- db 124,227,57,130,155,47,255,135
- db 52,142,67,68,196,222,233,203
- db 84,123,148,50,166,194,35,61
- db 238,76,149,11,66,250,195,78
- db 8,46,161,102,40,217,36,178
- db 118,91,162,73,109,139,209,37
- db 114,248,246,100,134,104,152,22
- db 212,164,92,204,93,101,182,146
- db 108,112,72,80,253,237,185,218
- db 94,21,70,87,167,141,157,132
- db 144,216,171,0,140,188,211,10
- db 247,228,88,5,184,179,69,6
- db 208,44,30,143,202,63,15,2
- db 193,175,189,3,1,19,138,107
- db 58,145,17,65,79,103,220,234
- db 151,242,207,206,240,180,230,115
- db 150,172,116,34,231,173,53,133
- db 226,249,55,232,28,117,223,110
- db 71,241,26,113,29,41,197,137
- db 111,183,98,14,170,24,190,27
- db 252,86,62,75,198,210,121,32
- db 154,219,192,254,120,205,90,244
- db 31,221,168,51,136,7,199,49
- db 177,18,16,89,39,128,236,95
- db 96,81,127,169,25,181,74,13
- db 45,229,122,159,147,201,156,239
- db 160,224,59,77,174,42,245,176
- db 200,235,187,60,131,83,153,97
- db 23,43,4,126,186,119,214,38
- db 225,105,20,99,85,33,12,125
- db 82,9,106,213,48,54,165,56
- db 191,64,163,158,129,243,215,251
- db 124,227,57,130,155,47,255,135
- db 52,142,67,68,196,222,233,203
- db 84,123,148,50,166,194,35,61
- db 238,76,149,11,66,250,195,78
- db 8,46,161,102,40,217,36,178
- db 118,91,162,73,109,139,209,37
- db 114,248,246,100,134,104,152,22
- db 212,164,92,204,93,101,182,146
- db 108,112,72,80,253,237,185,218
- db 94,21,70,87,167,141,157,132
- db 144,216,171,0,140,188,211,10
- db 247,228,88,5,184,179,69,6
- db 208,44,30,143,202,63,15,2
- db 193,175,189,3,1,19,138,107
- db 58,145,17,65,79,103,220,234
- db 151,242,207,206,240,180,230,115
- db 150,172,116,34,231,173,53,133
- db 226,249,55,232,28,117,223,110
- db 71,241,26,113,29,41,197,137
- db 111,183,98,14,170,24,190,27
- db 252,86,62,75,198,210,121,32
- db 154,219,192,254,120,205,90,244
- db 31,221,168,51,136,7,199,49
- db 177,18,16,89,39,128,236,95
- db 96,81,127,169,25,181,74,13
- db 45,229,122,159,147,201,156,239
- db 160,224,59,77,174,42,245,176
- db 200,235,187,60,131,83,153,97
- db 23,43,4,126,186,119,214,38
- db 225,105,20,99,85,33,12,125
- db 82,9,106,213,48,54,165,56
- db 191,64,163,158,129,243,215,251
- db 124,227,57,130,155,47,255,135
- db 52,142,67,68,196,222,233,203
- db 84,123,148,50,166,194,35,61
- db 238,76,149,11,66,250,195,78
- db 8,46,161,102,40,217,36,178
- db 118,91,162,73,109,139,209,37
- db 114,248,246,100,134,104,152,22
- db 212,164,92,204,93,101,182,146
- db 108,112,72,80,253,237,185,218
- db 94,21,70,87,167,141,157,132
- db 144,216,171,0,140,188,211,10
- db 247,228,88,5,184,179,69,6
- db 208,44,30,143,202,63,15,2
- db 193,175,189,3,1,19,138,107
- db 58,145,17,65,79,103,220,234
- db 151,242,207,206,240,180,230,115
- db 150,172,116,34,231,173,53,133
- db 226,249,55,232,28,117,223,110
- db 71,241,26,113,29,41,197,137
- db 111,183,98,14,170,24,190,27
- db 252,86,62,75,198,210,121,32
- db 154,219,192,254,120,205,90,244
- db 31,221,168,51,136,7,199,49
- db 177,18,16,89,39,128,236,95
- db 96,81,127,169,25,181,74,13
- db 45,229,122,159,147,201,156,239
- db 160,224,59,77,174,42,245,176
- db 200,235,187,60,131,83,153,97
- db 23,43,4,126,186,119,214,38
- db 225,105,20,99,85,33,12,125
- db 82,9,106,213,48,54,165,56
- db 191,64,163,158,129,243,215,251
- db 124,227,57,130,155,47,255,135
- db 52,142,67,68,196,222,233,203
- db 84,123,148,50,166,194,35,61
- db 238,76,149,11,66,250,195,78
- db 8,46,161,102,40,217,36,178
- db 118,91,162,73,109,139,209,37
- db 114,248,246,100,134,104,152,22
- db 212,164,92,204,93,101,182,146
- db 108,112,72,80,253,237,185,218
- db 94,21,70,87,167,141,157,132
- db 144,216,171,0,140,188,211,10
- db 247,228,88,5,184,179,69,6
- db 208,44,30,143,202,63,15,2
- db 193,175,189,3,1,19,138,107
- db 58,145,17,65,79,103,220,234
- db 151,242,207,206,240,180,230,115
- db 150,172,116,34,231,173,53,133
- db 226,249,55,232,28,117,223,110
- db 71,241,26,113,29,41,197,137
- db 111,183,98,14,170,24,190,27
- db 252,86,62,75,198,210,121,32
- db 154,219,192,254,120,205,90,244
- db 31,221,168,51,136,7,199,49
- db 177,18,16,89,39,128,236,95
- db 96,81,127,169,25,181,74,13
- db 45,229,122,159,147,201,156,239
- db 160,224,59,77,174,42,245,176
- db 200,235,187,60,131,83,153,97
- db 23,43,4,126,186,119,214,38
- db 225,105,20,99,85,33,12,125
- global _AES_decrypt
- align 16
- _AES_decrypt:
- L$_AES_decrypt_begin:
- push ebp
- push ebx
- push esi
- push edi
- mov esi,DWORD [20+esp]
- mov edi,DWORD [28+esp]
- mov eax,esp
- sub esp,36
- and esp,-64
- lea ebx,[edi-127]
- sub ebx,esp
- neg ebx
- and ebx,960
- sub esp,ebx
- add esp,4
- mov DWORD [28+esp],eax
- call L$006pic_point
- L$006pic_point:
- pop ebp
- lea ebp,[(L$AES_Td-L$006pic_point)+ebp]
- lea ebx,[764+esp]
- sub ebx,ebp
- and ebx,768
- lea ebp,[2176+ebx*1+ebp]
- align 16
- L$007x86:
- mov DWORD [24+esp],ebp
- mov eax,DWORD [esi]
- mov ebx,DWORD [4+esi]
- mov ecx,DWORD [8+esi]
- mov edx,DWORD [12+esi]
- call __x86_AES_decrypt_compact
- mov esp,DWORD [28+esp]
- mov esi,DWORD [24+esp]
- mov DWORD [esi],eax
- mov DWORD [4+esi],ebx
- mov DWORD [8+esi],ecx
- mov DWORD [12+esi],edx
- pop edi
- pop esi
- pop ebx
- pop ebp
- ret
- global _AES_cbc_encrypt
- align 16
- _AES_cbc_encrypt:
- L$_AES_cbc_encrypt_begin:
- push ebp
- push ebx
- push esi
- push edi
- mov ecx,DWORD [28+esp]
- cmp ecx,0
- je NEAR L$008drop_out
- call L$009pic_point
- L$009pic_point:
- pop ebp
- cmp DWORD [40+esp],0
- lea ebp,[(L$AES_Te-L$009pic_point)+ebp]
- jne NEAR L$010picked_te
- lea ebp,[(L$AES_Td-L$AES_Te)+ebp]
- L$010picked_te:
- pushfd
- cld
- cmp ecx,512
- jb NEAR L$011slow_way
- test ecx,15
- jnz NEAR L$011slow_way
- lea esi,[esp-324]
- and esi,-64
- mov eax,ebp
- lea ebx,[2304+ebp]
- mov edx,esi
- and eax,4095
- and ebx,4095
- and edx,4095
- cmp edx,ebx
- jb NEAR L$012tbl_break_out
- sub edx,ebx
- sub esi,edx
- jmp NEAR L$013tbl_ok
- align 4
- L$012tbl_break_out:
- sub edx,eax
- and edx,4095
- add edx,384
- sub esi,edx
- align 4
- L$013tbl_ok:
- lea edx,[24+esp]
- xchg esp,esi
- add esp,4
- mov DWORD [24+esp],ebp
- mov DWORD [28+esp],esi
- mov eax,DWORD [edx]
- mov ebx,DWORD [4+edx]
- mov edi,DWORD [12+edx]
- mov esi,DWORD [16+edx]
- mov edx,DWORD [20+edx]
- mov DWORD [32+esp],eax
- mov DWORD [36+esp],ebx
- mov DWORD [40+esp],ecx
- mov DWORD [44+esp],edi
- mov DWORD [48+esp],esi
- mov DWORD [316+esp],0
- mov ebx,edi
- mov ecx,61
- sub ebx,ebp
- mov esi,edi
- and ebx,4095
- lea edi,[76+esp]
- cmp ebx,2304
- jb NEAR L$014do_copy
- cmp ebx,3852
- jb NEAR L$015skip_copy
- align 4
- L$014do_copy:
- mov DWORD [44+esp],edi
- dd 2784229001
- L$015skip_copy:
- mov edi,16
- align 4
- L$016prefetch_tbl:
- mov eax,DWORD [ebp]
- mov ebx,DWORD [32+ebp]
- mov ecx,DWORD [64+ebp]
- mov esi,DWORD [96+ebp]
- lea ebp,[128+ebp]
- sub edi,1
- jnz NEAR L$016prefetch_tbl
- sub ebp,2048
- mov esi,DWORD [32+esp]
- mov edi,DWORD [48+esp]
- cmp edx,0
- je NEAR L$017fast_decrypt
- mov eax,DWORD [edi]
- mov ebx,DWORD [4+edi]
- align 16
- L$018fast_enc_loop:
- mov ecx,DWORD [8+edi]
- mov edx,DWORD [12+edi]
- xor eax,DWORD [esi]
- xor ebx,DWORD [4+esi]
- xor ecx,DWORD [8+esi]
- xor edx,DWORD [12+esi]
- mov edi,DWORD [44+esp]
- call __x86_AES_encrypt
- mov esi,DWORD [32+esp]
- mov edi,DWORD [36+esp]
- mov DWORD [edi],eax
- mov DWORD [4+edi],ebx
- mov DWORD [8+edi],ecx
- mov DWORD [12+edi],edx
- lea esi,[16+esi]
- mov ecx,DWORD [40+esp]
- mov DWORD [32+esp],esi
- lea edx,[16+edi]
- mov DWORD [36+esp],edx
- sub ecx,16
- mov DWORD [40+esp],ecx
- jnz NEAR L$018fast_enc_loop
- mov esi,DWORD [48+esp]
- mov ecx,DWORD [8+edi]
- mov edx,DWORD [12+edi]
- mov DWORD [esi],eax
- mov DWORD [4+esi],ebx
- mov DWORD [8+esi],ecx
- mov DWORD [12+esi],edx
- cmp DWORD [316+esp],0
- mov edi,DWORD [44+esp]
- je NEAR L$019skip_ezero
- mov ecx,60
- xor eax,eax
- align 4
- dd 2884892297
- L$019skip_ezero:
- mov esp,DWORD [28+esp]
- popfd
- L$008drop_out:
- pop edi
- pop esi
- pop ebx
- pop ebp
- ret
- pushfd
- align 16
- L$017fast_decrypt:
- cmp esi,DWORD [36+esp]
- je NEAR L$020fast_dec_in_place
- mov DWORD [52+esp],edi
- align 4
- align 16
- L$021fast_dec_loop:
- mov eax,DWORD [esi]
- mov ebx,DWORD [4+esi]
- mov ecx,DWORD [8+esi]
- mov edx,DWORD [12+esi]
- mov edi,DWORD [44+esp]
- call __x86_AES_decrypt
- mov edi,DWORD [52+esp]
- mov esi,DWORD [40+esp]
- xor eax,DWORD [edi]
- xor ebx,DWORD [4+edi]
- xor ecx,DWORD [8+edi]
- xor edx,DWORD [12+edi]
- mov edi,DWORD [36+esp]
- mov esi,DWORD [32+esp]
- mov DWORD [edi],eax
- mov DWORD [4+edi],ebx
- mov DWORD [8+edi],ecx
- mov DWORD [12+edi],edx
- mov ecx,DWORD [40+esp]
- mov DWORD [52+esp],esi
- lea esi,[16+esi]
- mov DWORD [32+esp],esi
- lea edi,[16+edi]
- mov DWORD [36+esp],edi
- sub ecx,16
- mov DWORD [40+esp],ecx
- jnz NEAR L$021fast_dec_loop
- mov edi,DWORD [52+esp]
- mov esi,DWORD [48+esp]
- mov eax,DWORD [edi]
- mov ebx,DWORD [4+edi]
- mov ecx,DWORD [8+edi]
- mov edx,DWORD [12+edi]
- mov DWORD [esi],eax
- mov DWORD [4+esi],ebx
- mov DWORD [8+esi],ecx
- mov DWORD [12+esi],edx
- jmp NEAR L$022fast_dec_out
- align 16
- L$020fast_dec_in_place:
- L$023fast_dec_in_place_loop:
- mov eax,DWORD [esi]
- mov ebx,DWORD [4+esi]
- mov ecx,DWORD [8+esi]
- mov edx,DWORD [12+esi]
- lea edi,[60+esp]
- mov DWORD [edi],eax
- mov DWORD [4+edi],ebx
- mov DWORD [8+edi],ecx
- mov DWORD [12+edi],edx
- mov edi,DWORD [44+esp]
- call __x86_AES_decrypt
- mov edi,DWORD [48+esp]
- mov esi,DWORD [36+esp]
- xor eax,DWORD [edi]
- xor ebx,DWORD [4+edi]
- xor ecx,DWORD [8+edi]
- xor edx,DWORD [12+edi]
- mov DWORD [esi],eax
- mov DWORD [4+esi],ebx
- mov DWORD [8+esi],ecx
- mov DWORD [12+esi],edx
- lea esi,[16+esi]
- mov DWORD [36+esp],esi
- lea esi,[60+esp]
- mov eax,DWORD [esi]
- mov ebx,DWORD [4+esi]
- mov ecx,DWORD [8+esi]
- mov edx,DWORD [12+esi]
- mov DWORD [edi],eax
- mov DWORD [4+edi],ebx
- mov DWORD [8+edi],ecx
- mov DWORD [12+edi],edx
- mov esi,DWORD [32+esp]
- mov ecx,DWORD [40+esp]
- lea esi,[16+esi]
- mov DWORD [32+esp],esi
- sub ecx,16
- mov DWORD [40+esp],ecx
- jnz NEAR L$023fast_dec_in_place_loop
- align 4
- L$022fast_dec_out:
- cmp DWORD [316+esp],0
- mov edi,DWORD [44+esp]
- je NEAR L$024skip_dzero
- mov ecx,60
- xor eax,eax
- align 4
- dd 2884892297
- L$024skip_dzero:
- mov esp,DWORD [28+esp]
- popfd
- pop edi
- pop esi
- pop ebx
- pop ebp
- ret
- pushfd
- align 16
- L$011slow_way:
- mov edi,DWORD [36+esp]
- lea esi,[esp-80]
- and esi,-64
- lea ebx,[edi-143]
- sub ebx,esi
- neg ebx
- and ebx,960
- sub esi,ebx
- lea ebx,[768+esi]
- sub ebx,ebp
- and ebx,768
- lea ebp,[2176+ebx*1+ebp]
- lea edx,[24+esp]
- xchg esp,esi
- add esp,4
- mov DWORD [24+esp],ebp
- mov DWORD [28+esp],esi
- mov DWORD [52+esp],eax
- mov eax,DWORD [edx]
- mov ebx,DWORD [4+edx]
- mov esi,DWORD [16+edx]
- mov edx,DWORD [20+edx]
- mov DWORD [32+esp],eax
- mov DWORD [36+esp],ebx
- mov DWORD [40+esp],ecx
- mov DWORD [44+esp],edi
- mov DWORD [48+esp],esi
- mov edi,esi
- mov esi,eax
- cmp edx,0
- je NEAR L$025slow_decrypt
- cmp ecx,16
- mov edx,ebx
- jb NEAR L$026slow_enc_tail
- align 16
- L$027slow_enc_x86:
- mov eax,DWORD [edi]
- mov ebx,DWORD [4+edi]
- align 4
- L$028slow_enc_loop_x86:
- mov ecx,DWORD [8+edi]
- mov edx,DWORD [12+edi]
- xor eax,DWORD [esi]
- xor ebx,DWORD [4+esi]
- xor ecx,DWORD [8+esi]
- xor edx,DWORD [12+esi]
- mov edi,DWORD [44+esp]
- call __x86_AES_encrypt_compact
- mov esi,DWORD [32+esp]
- mov edi,DWORD [36+esp]
- mov DWORD [edi],eax
- mov DWORD [4+edi],ebx
- mov DWORD [8+edi],ecx
- mov DWORD [12+edi],edx
- mov ecx,DWORD [40+esp]
- lea esi,[16+esi]
- mov DWORD [32+esp],esi
- lea edx,[16+edi]
- mov DWORD [36+esp],edx
- sub ecx,16
- cmp ecx,16
- mov DWORD [40+esp],ecx
- jae NEAR L$028slow_enc_loop_x86
- test ecx,15
- jnz NEAR L$026slow_enc_tail
- mov esi,DWORD [48+esp]
- mov ecx,DWORD [8+edi]
- mov edx,DWORD [12+edi]
- mov DWORD [esi],eax
- mov DWORD [4+esi],ebx
- mov DWORD [8+esi],ecx
- mov DWORD [12+esi],edx
- mov esp,DWORD [28+esp]
- popfd
- pop edi
- pop esi
- pop ebx
- pop ebp
- ret
- pushfd
- align 16
- L$026slow_enc_tail:
- mov edi,edx
- mov ebx,16
- sub ebx,ecx
- cmp edi,esi
- je NEAR L$029enc_in_place
- align 4
- dd 2767451785
- jmp NEAR L$030enc_skip_in_place
- L$029enc_in_place:
- lea edi,[ecx*1+edi]
- L$030enc_skip_in_place:
- mov ecx,ebx
- xor eax,eax
- align 4
- dd 2868115081
- mov edi,DWORD [48+esp]
- mov esi,edx
- mov eax,DWORD [edi]
- mov ebx,DWORD [4+edi]
- mov DWORD [40+esp],16
- jmp NEAR L$028slow_enc_loop_x86
- align 16
- L$025slow_decrypt:
- align 16
- L$031slow_dec_loop_x86:
- mov eax,DWORD [esi]
- mov ebx,DWORD [4+esi]
- mov ecx,DWORD [8+esi]
- mov edx,DWORD [12+esi]
- lea edi,[60+esp]
- mov DWORD [edi],eax
- mov DWORD [4+edi],ebx
- mov DWORD [8+edi],ecx
- mov DWORD [12+edi],edx
- mov edi,DWORD [44+esp]
- call __x86_AES_decrypt_compact
- mov edi,DWORD [48+esp]
- mov esi,DWORD [40+esp]
- xor eax,DWORD [edi]
- xor ebx,DWORD [4+edi]
- xor ecx,DWORD [8+edi]
- xor edx,DWORD [12+edi]
- sub esi,16
- jc NEAR L$032slow_dec_partial_x86
- mov DWORD [40+esp],esi
- mov esi,DWORD [36+esp]
- mov DWORD [esi],eax
- mov DWORD [4+esi],ebx
- mov DWORD [8+esi],ecx
- mov DWORD [12+esi],edx
- lea esi,[16+esi]
- mov DWORD [36+esp],esi
- lea esi,[60+esp]
- mov eax,DWORD [esi]
- mov ebx,DWORD [4+esi]
- mov ecx,DWORD [8+esi]
- mov edx,DWORD [12+esi]
- mov DWORD [edi],eax
- mov DWORD [4+edi],ebx
- mov DWORD [8+edi],ecx
- mov DWORD [12+edi],edx
- mov esi,DWORD [32+esp]
- lea esi,[16+esi]
- mov DWORD [32+esp],esi
- jnz NEAR L$031slow_dec_loop_x86
- mov esp,DWORD [28+esp]
- popfd
- pop edi
- pop esi
- pop ebx
- pop ebp
- ret
- pushfd
- align 16
- L$032slow_dec_partial_x86:
- lea esi,[60+esp]
- mov DWORD [esi],eax
- mov DWORD [4+esi],ebx
- mov DWORD [8+esi],ecx
- mov DWORD [12+esi],edx
- mov esi,DWORD [32+esp]
- mov eax,DWORD [esi]
- mov ebx,DWORD [4+esi]
- mov ecx,DWORD [8+esi]
- mov edx,DWORD [12+esi]
- mov DWORD [edi],eax
- mov DWORD [4+edi],ebx
- mov DWORD [8+edi],ecx
- mov DWORD [12+edi],edx
- mov ecx,DWORD [40+esp]
- mov edi,DWORD [36+esp]
- lea esi,[60+esp]
- align 4
- dd 2767451785
- mov esp,DWORD [28+esp]
- popfd
- pop edi
- pop esi
- pop ebx
- pop ebp
- ret
- align 16
- __x86_AES_set_encrypt_key:
- push ebp
- push ebx
- push esi
- push edi
- mov esi,DWORD [24+esp]
- mov edi,DWORD [32+esp]
- test esi,-1
- jz NEAR L$033badpointer
- test edi,-1
- jz NEAR L$033badpointer
- call L$034pic_point
- L$034pic_point:
- pop ebp
- lea ebp,[(L$AES_Te-L$034pic_point)+ebp]
- lea ebp,[2176+ebp]
- mov eax,DWORD [ebp-128]
- mov ebx,DWORD [ebp-96]
- mov ecx,DWORD [ebp-64]
- mov edx,DWORD [ebp-32]
- mov eax,DWORD [ebp]
- mov ebx,DWORD [32+ebp]
- mov ecx,DWORD [64+ebp]
- mov edx,DWORD [96+ebp]
- mov ecx,DWORD [28+esp]
- cmp ecx,128
- je NEAR L$03510rounds
- cmp ecx,192
- je NEAR L$03612rounds
- cmp ecx,256
- je NEAR L$03714rounds
- mov eax,-2
- jmp NEAR L$038exit
- L$03510rounds:
- mov eax,DWORD [esi]
- mov ebx,DWORD [4+esi]
- mov ecx,DWORD [8+esi]
- mov edx,DWORD [12+esi]
- mov DWORD [edi],eax
- mov DWORD [4+edi],ebx
- mov DWORD [8+edi],ecx
- mov DWORD [12+edi],edx
- xor ecx,ecx
- jmp NEAR L$03910shortcut
- align 4
- L$04010loop:
- mov eax,DWORD [edi]
- mov edx,DWORD [12+edi]
- L$03910shortcut:
- movzx esi,dl
- movzx ebx,BYTE [esi*1+ebp-128]
- movzx esi,dh
- shl ebx,24
- xor eax,ebx
- movzx ebx,BYTE [esi*1+ebp-128]
- shr edx,16
- movzx esi,dl
- xor eax,ebx
- movzx ebx,BYTE [esi*1+ebp-128]
- movzx esi,dh
- shl ebx,8
- xor eax,ebx
- movzx ebx,BYTE [esi*1+ebp-128]
- shl ebx,16
- xor eax,ebx
- xor eax,DWORD [896+ecx*4+ebp]
- mov DWORD [16+edi],eax
- xor eax,DWORD [4+edi]
- mov DWORD [20+edi],eax
- xor eax,DWORD [8+edi]
- mov DWORD [24+edi],eax
- xor eax,DWORD [12+edi]
- mov DWORD [28+edi],eax
- inc ecx
- add edi,16
- cmp ecx,10
- jl NEAR L$04010loop
- mov DWORD [80+edi],10
- xor eax,eax
- jmp NEAR L$038exit
- L$03612rounds:
- mov eax,DWORD [esi]
- mov ebx,DWORD [4+esi]
- mov ecx,DWORD [8+esi]
- mov edx,DWORD [12+esi]
- mov DWORD [edi],eax
- mov DWORD [4+edi],ebx
- mov DWORD [8+edi],ecx
- mov DWORD [12+edi],edx
- mov ecx,DWORD [16+esi]
- mov edx,DWORD [20+esi]
- mov DWORD [16+edi],ecx
- mov DWORD [20+edi],edx
- xor ecx,ecx
- jmp NEAR L$04112shortcut
- align 4
- L$04212loop:
- mov eax,DWORD [edi]
- mov edx,DWORD [20+edi]
- L$04112shortcut:
- movzx esi,dl
- movzx ebx,BYTE [esi*1+ebp-128]
- movzx esi,dh
- shl ebx,24
- xor eax,ebx
- movzx ebx,BYTE [esi*1+ebp-128]
- shr edx,16
- movzx esi,dl
- xor eax,ebx
- movzx ebx,BYTE [esi*1+ebp-128]
- movzx esi,dh
- shl ebx,8
- xor eax,ebx
- movzx ebx,BYTE [esi*1+ebp-128]
- shl ebx,16
- xor eax,ebx
- xor eax,DWORD [896+ecx*4+ebp]
- mov DWORD [24+edi],eax
- xor eax,DWORD [4+edi]
- mov DWORD [28+edi],eax
- xor eax,DWORD [8+edi]
- mov DWORD [32+edi],eax
- xor eax,DWORD [12+edi]
- mov DWORD [36+edi],eax
- cmp ecx,7
- je NEAR L$04312break
- inc ecx
- xor eax,DWORD [16+edi]
- mov DWORD [40+edi],eax
- xor eax,DWORD [20+edi]
- mov DWORD [44+edi],eax
- add edi,24
- jmp NEAR L$04212loop
- L$04312break:
- mov DWORD [72+edi],12
- xor eax,eax
- jmp NEAR L$038exit
- L$03714rounds:
- mov eax,DWORD [esi]
- mov ebx,DWORD [4+esi]
- mov ecx,DWORD [8+esi]
- mov edx,DWORD [12+esi]
- mov DWORD [edi],eax
- mov DWORD [4+edi],ebx
- mov DWORD [8+edi],ecx
- mov DWORD [12+edi],edx
- mov eax,DWORD [16+esi]
- mov ebx,DWORD [20+esi]
- mov ecx,DWORD [24+esi]
- mov edx,DWORD [28+esi]
- mov DWORD [16+edi],eax
- mov DWORD [20+edi],ebx
- mov DWORD [24+edi],ecx
- mov DWORD [28+edi],edx
- xor ecx,ecx
- jmp NEAR L$04414shortcut
- align 4
- L$04514loop:
- mov edx,DWORD [28+edi]
- L$04414shortcut:
- mov eax,DWORD [edi]
- movzx esi,dl
- movzx ebx,BYTE [esi*1+ebp-128]
- movzx esi,dh
- shl ebx,24
- xor eax,ebx
- movzx ebx,BYTE [esi*1+ebp-128]
- shr edx,16
- movzx esi,dl
- xor eax,ebx
- movzx ebx,BYTE [esi*1+ebp-128]
- movzx esi,dh
- shl ebx,8
- xor eax,ebx
- movzx ebx,BYTE [esi*1+ebp-128]
- shl ebx,16
- xor eax,ebx
- xor eax,DWORD [896+ecx*4+ebp]
- mov DWORD [32+edi],eax
- xor eax,DWORD [4+edi]
- mov DWORD [36+edi],eax
- xor eax,DWORD [8+edi]
- mov DWORD [40+edi],eax
- xor eax,DWORD [12+edi]
- mov DWORD [44+edi],eax
- cmp ecx,6
- je NEAR L$04614break
- inc ecx
- mov edx,eax
- mov eax,DWORD [16+edi]
- movzx esi,dl
- movzx ebx,BYTE [esi*1+ebp-128]
- movzx esi,dh
- xor eax,ebx
- movzx ebx,BYTE [esi*1+ebp-128]
- shr edx,16
- shl ebx,8
- movzx esi,dl
- xor eax,ebx
- movzx ebx,BYTE [esi*1+ebp-128]
- movzx esi,dh
- shl ebx,16
- xor eax,ebx
- movzx ebx,BYTE [esi*1+ebp-128]
- shl ebx,24
- xor eax,ebx
- mov DWORD [48+edi],eax
- xor eax,DWORD [20+edi]
- mov DWORD [52+edi],eax
- xor eax,DWORD [24+edi]
- mov DWORD [56+edi],eax
- xor eax,DWORD [28+edi]
- mov DWORD [60+edi],eax
- add edi,32
- jmp NEAR L$04514loop
- L$04614break:
- mov DWORD [48+edi],14
- xor eax,eax
- jmp NEAR L$038exit
- L$033badpointer:
- mov eax,-1
- L$038exit:
- pop edi
- pop esi
- pop ebx
- pop ebp
- ret
- global _AES_set_encrypt_key
- align 16
- _AES_set_encrypt_key:
- L$_AES_set_encrypt_key_begin:
- call __x86_AES_set_encrypt_key
- ret
- global _AES_set_decrypt_key
- align 16
- _AES_set_decrypt_key:
- L$_AES_set_decrypt_key_begin:
- call __x86_AES_set_encrypt_key
- cmp eax,0
- je NEAR L$047proceed
- ret
- L$047proceed:
- push ebp
- push ebx
- push esi
- push edi
- mov esi,DWORD [28+esp]
- mov ecx,DWORD [240+esi]
- lea ecx,[ecx*4]
- lea edi,[ecx*4+esi]
- align 4
- L$048invert:
- mov eax,DWORD [esi]
- mov ebx,DWORD [4+esi]
- mov ecx,DWORD [edi]
- mov edx,DWORD [4+edi]
- mov DWORD [edi],eax
- mov DWORD [4+edi],ebx
- mov DWORD [esi],ecx
- mov DWORD [4+esi],edx
- mov eax,DWORD [8+esi]
- mov ebx,DWORD [12+esi]
- mov ecx,DWORD [8+edi]
- mov edx,DWORD [12+edi]
- mov DWORD [8+edi],eax
- mov DWORD [12+edi],ebx
- mov DWORD [8+esi],ecx
- mov DWORD [12+esi],edx
- add esi,16
- sub edi,16
- cmp esi,edi
- jne NEAR L$048invert
- mov edi,DWORD [28+esp]
- mov esi,DWORD [240+edi]
- lea esi,[esi*1+esi-2]
- lea esi,[esi*8+edi]
- mov DWORD [28+esp],esi
- mov eax,DWORD [16+edi]
- align 4
- L$049permute:
- add edi,16
- mov ebp,2155905152
- and ebp,eax
- lea ebx,[eax*1+eax]
- mov esi,ebp
- shr ebp,7
- sub esi,ebp
- and ebx,4278124286
- and esi,454761243
- xor ebx,esi
- mov ebp,2155905152
- and ebp,ebx
- lea ecx,[ebx*1+ebx]
- mov esi,ebp
- shr ebp,7
- sub esi,ebp
- and ecx,4278124286
- and esi,454761243
- xor ebx,eax
- xor ecx,esi
- mov ebp,2155905152
- and ebp,ecx
- lea edx,[ecx*1+ecx]
- mov esi,ebp
- shr ebp,7
- xor ecx,eax
- sub esi,ebp
- and edx,4278124286
- and esi,454761243
- rol eax,8
- xor edx,esi
- mov ebp,DWORD [4+edi]
- xor eax,ebx
- xor ebx,edx
- xor eax,ecx
- rol ebx,24
- xor ecx,edx
- xor eax,edx
- rol ecx,16
- xor eax,ebx
- rol edx,8
- xor eax,ecx
- mov ebx,ebp
- xor eax,edx
- mov DWORD [edi],eax
- mov ebp,2155905152
- and ebp,ebx
- lea ecx,[ebx*1+ebx]
- mov esi,ebp
- shr ebp,7
- sub esi,ebp
- and ecx,4278124286
- and esi,454761243
- xor ecx,esi
- mov ebp,2155905152
- and ebp,ecx
- lea edx,[ecx*1+ecx]
- mov esi,ebp
- shr ebp,7
- sub esi,ebp
- and edx,4278124286
- and esi,454761243
- xor ecx,ebx
- xor edx,esi
- mov ebp,2155905152
- and ebp,edx
- lea eax,[edx*1+edx]
- mov esi,ebp
- shr ebp,7
- xor edx,ebx
- sub esi,ebp
- and eax,4278124286
- and esi,454761243
- rol ebx,8
- xor eax,esi
- mov ebp,DWORD [8+edi]
- xor ebx,ecx
- xor ecx,eax
- xor ebx,edx
- rol ecx,24
- xor edx,eax
- xor ebx,eax
- rol edx,16
- xor ebx,ecx
- rol eax,8
- xor ebx,edx
- mov ecx,ebp
- xor ebx,eax
- mov DWORD [4+edi],ebx
- mov ebp,2155905152
- and ebp,ecx
- lea edx,[ecx*1+ecx]
- mov esi,ebp
- shr ebp,7
- sub esi,ebp
- and edx,4278124286
- and esi,454761243
- xor edx,esi
- mov ebp,2155905152
- and ebp,edx
- lea eax,[edx*1+edx]
- mov esi,ebp
- shr ebp,7
- sub esi,ebp
- and eax,4278124286
- and esi,454761243
- xor edx,ecx
- xor eax,esi
- mov ebp,2155905152
- and ebp,eax
- lea ebx,[eax*1+eax]
- mov esi,ebp
- shr ebp,7
- xor eax,ecx
- sub esi,ebp
- and ebx,4278124286
- and esi,454761243
- rol ecx,8
- xor ebx,esi
- mov ebp,DWORD [12+edi]
- xor ecx,edx
- xor edx,ebx
- xor ecx,eax
- rol edx,24
- xor eax,ebx
- xor ecx,ebx
- rol eax,16
- xor ecx,edx
- rol ebx,8
- xor ecx,eax
- mov edx,ebp
- xor ecx,ebx
- mov DWORD [8+edi],ecx
- mov ebp,2155905152
- and ebp,edx
- lea eax,[edx*1+edx]
- mov esi,ebp
- shr ebp,7
- sub esi,ebp
- and eax,4278124286
- and esi,454761243
- xor eax,esi
- mov ebp,2155905152
- and ebp,eax
- lea ebx,[eax*1+eax]
- mov esi,ebp
- shr ebp,7
- sub esi,ebp
- and ebx,4278124286
- and esi,454761243
- xor eax,edx
- xor ebx,esi
- mov ebp,2155905152
- and ebp,ebx
- lea ecx,[ebx*1+ebx]
- mov esi,ebp
- shr ebp,7
- xor ebx,edx
- sub esi,ebp
- and ecx,4278124286
- and esi,454761243
- rol edx,8
- xor ecx,esi
- mov ebp,DWORD [16+edi]
- xor edx,eax
- xor eax,ecx
- xor edx,ebx
- rol eax,24
- xor ebx,ecx
- xor edx,ecx
- rol ebx,16
- xor edx,eax
- rol ecx,8
- xor edx,ebx
- mov eax,ebp
- xor edx,ecx
- mov DWORD [12+edi],edx
- cmp edi,DWORD [28+esp]
- jb NEAR L$049permute
- xor eax,eax
- pop edi
- pop esi
- pop ebx
- pop ebp
- ret
- db 65,69,83,32,102,111,114,32,120,56,54,44,32,67,82,89
- db 80,84,79,71,65,77,83,32,98,121,32,60,97,112,112,114
- db 111,64,111,112,101,110,115,115,108,46,111,114,103,62,0
|