00C51002 in al,dx
00C51003 and esp,0FFFFFFC0h
00C51006 sub esp,0C0h
00C5100C mov eax,dword ptr [___security_cookie (0C53000h)]
00C51011 xor eax,esp
00C51013 mov dword ptr [esp+0BCh],eax
int count = 16;
__int64 inputs_hex[16] = {
0x0000000000000000, 0x0000000000000000, 0x0000000000000000, 0x1fedb1530240aa54,
00C5101A xor eax,eax
00C5101C mov dword ptr [esp+38h],eax
00C51020 mov dword ptr [esp+3Ch],eax
00C51024 mov dword ptr [esp+40h],eax
00C51028 mov dword ptr [esp+44h],eax
00C5102C mov dword ptr [esp+48h],eax
00C51030 mov dword ptr [esp+4Ch],eax
0x0000000000000000, 0x0000000000000000, 0x0000000000000000, 0x1ff0af0d95025bc3,
00C51034 mov dword ptr [esp+58h],eax
00C51038 mov dword ptr [esp+5Ch],eax
00C5103C mov dword ptr [esp+60h],eax
00C51040 mov dword ptr [esp+64h],eax
00C51044 mov dword ptr [esp+68h],eax
00C51048 mov dword ptr [esp+6Ch],eax
0x1fc9353df6af376b, 0x0000000000000000, 0x0000000000000000, 0x0000000000000000,
00C5104C mov dword ptr [esp+80h],eax
00C51053 mov dword ptr [esp+84h],eax
00C5105A mov dword ptr [esp+88h],eax
00C51061 mov dword ptr [esp+8Ch],eax
00C51068 mov dword ptr [esp+90h],eax
00C5106F mov dword ptr [esp+94h],eax
0x0000000000000000, 0x0000000000000000, 0x0000000000000000, 0x0000000000000000
00C51076 mov dword ptr [esp+98h],eax
00C5107D mov dword ptr [esp+9Ch],eax
00C51084 mov dword ptr [esp+0A0h],eax
00C5108B mov dword ptr [esp+0A4h],eax
00C51092 mov dword ptr [esp+0A8h],eax
00C51099 mov dword ptr [esp+0ACh],eax
};
00C510A0 mov dword ptr [esp+0B0h],eax
00C510A7 mov dword ptr [esp+0B4h],eax
double* inputs = (double*)inputs_hex;
double norm = calc_norm_and_regulate(count, inputs, false);
00C510AE lea eax,[esp+38h]
00C510B2 mov dword ptr [esp+50h],240AA54h
00C510BA mov dword ptr [esp+54h],1FEDB153h
00C510C2 mov dword ptr [esp+70h],95025BC3h
00C510CA mov dword ptr [esp+74h],1FF0AF0Dh
00C510D2 mov dword ptr [esp+78h],0F6AF376Bh
00C510DA mov dword ptr [esp+7Ch],1FC9353Dh
00C510E2 call calc_norm_and_regulate<double> (0C51130h)
00C510E7 fst qword ptr [esp+30h]
fprintf(stdout, "[2]0x%016llX:%.19lg\n", *(uint64_t*)&norm, norm);
00C510EB mov eax,dword ptr [esp+34h]
00C510EF mov ecx,dword ptr [esp+30h]
00C510F3 sub esp,8
00C510F6 fstp qword ptr [esp]
00C510F9 push eax
00C510FA push ecx
00C510FB push offset string "[2]0x%016llX:%.19lg\n" (0C520F4h)
00C51100 call dword ptr [__imp____iob_func (0C5209Ch)]
00C51106 add eax,20h
00C51109 push eax
00C5110A call dword ptr [__imp__fprintf (0C520A4h)]
return 0;
}
00C51110 mov ecx,dword ptr [esp+0D4h]
00C51117 add esp,18h
00C5111A xor ecx,esp
00C5111C xor eax,eax
00C5111E call __security_check_cookie (0C511D5h)
00C51123 mov esp,ebp
00C51125 pop ebp
00C51126 ret
--- ソース ファイルがありません -------------------------------------------------------------
00C51127 int 3
00C51128 int 3
00C51129 int 3
00C5112A int 3
00C5112B int 3
00C5112C int 3
00C5112D int 3
00C5112E int 3
00C5112F int 3
--- c:\mingw\msys\1.0\home\root\double2\double2\double2.cpp --------------------
#include "stdafx.h"
#include <stdio.h>
#include <stdint.h>
#include <math.h>
template<typename T> static double calc_norm_and_regulate(int num, T* r, bool regulate){ // <float> for debug.
00C51130 push ebp
00C51131 mov ebp,esp
00C51133 sub esp,10h
double norm = 0;
00C51136 fldz
00C51138 add eax,10h
00C5113B fstp qword ptr [norm]
00C5113E mov ecx,2
00C51143 jmp calc_norm_and_regulate<double>+17h (0C51147h)
00C51145 fstp st(0)
for (int i = 0; i < num; i++) {
norm += (double)r[i] * (double)r[i];
00C51147 fld qword ptr [eax-10h]
00C5114A add eax,40h
00C5114D dec ecx
00C5114E fld qword ptr [eax-48h]
00C51151 fld qword ptr [eax-40h]
00C51154 fld qword ptr [eax-38h]
00C51157 fld qword ptr [eax-30h]
00C5115A fld qword ptr [eax-28h]
00C5115D fld qword ptr [eax-20h]
00C51160 fld qword ptr [eax-18h]
00C51163 fstp qword ptr [ebp-10h]
00C51166 fld st(6)
00C51168 fmulp st(7),st
00C5116A fxch st(6)
00C5116C fadd qword ptr [norm]
00C5116F fld st(5)
00C51171 fmulp st(6),st
00C51173 faddp st(5),st
00C51175 fld st(3)
00C51177 fmulp st(4),st
00C51179 fxch st(4)
00C5117B faddp st(3),st
00C5117D fld st(1)
00C5117F fmulp st(2),st
00C51181 fxch st(2)
00C51183 faddp st(1),st
00C51185 fld st(1)
00C51187 fmulp st(2),st
00C51189 faddp st(1),st
00C5118B fld st(1)
00C5118D fmulp st(2),st
00C5118F faddp st(1),st
00C51191 fld st(1)
00C51193 fmulp st(2),st
00C51195 faddp st(1),st
00C51197 fld qword ptr [ebp-10h]
00C5119A fmul st(0),st
00C5119C faddp st(1),st
00C5119E fst qword ptr [norm]
00C511A1 jne calc_norm_and_regulate<double>+15h (0C51145h)
// fprintf(stdout, "[0]0x%016llX:%.19lg\n", *(uint64_t*)&norm, norm);
}
fprintf(stdout, "[1]0x%016llX:%.19lg\n", *(uint64_t*)&norm, norm);
00C511A3 mov eax,dword ptr [ebp-4]
00C511A6 mov ecx,dword ptr [norm]
00C511A9 sub esp,8
00C511AC fstp qword ptr [esp]
00C511AF push eax
00C511B0 push ecx
00C511B1 push offset string "[1]0x%016llX:%.19lg\n" (0C5210Ch)
00C511B6 call dword ptr [__imp____iob_func (0C5209Ch)]
00C511BC add eax,20h
00C511BF push eax
00C511C0 call dword ptr [__imp__fprintf (0C520A4h)]
norm = sqrt(norm);
00C511C6 fld qword ptr [norm]
00C511C9 add esp,18h
00C511CC call _CIsqrt (0C519D0h)
if (regulate)
for (int i=0;i<num;i++)
r[i] = (T)(r[i]/norm);
return norm;
}
00C511D1 mov esp,ebp
00C511D3 pop ebp
00C511D4 ret
00C51002  in          al,dx  
00C51003  and         esp,0FFFFFFC0h  
00C51006  sub         esp,0C0h  
00C5100C  mov         eax,dword ptr [___security_cookie (0C53000h)]  
00C51011  xor         eax,esp  
00C51013  mov         dword ptr [esp+0BCh],eax  
	int count = 16;
	__int64 inputs_hex[16] = {
		0x0000000000000000, 0x0000000000000000, 0x0000000000000000, 0x1fedb1530240aa54,
00C5101A  xor         eax,eax  
00C5101C  mov         dword ptr [esp+38h],eax  
00C51020  mov         dword ptr [esp+3Ch],eax  
00C51024  mov         dword ptr [esp+40h],eax  
00C51028  mov         dword ptr [esp+44h],eax  
00C5102C  mov         dword ptr [esp+48h],eax  
00C51030  mov         dword ptr [esp+4Ch],eax  
		0x0000000000000000, 0x0000000000000000, 0x0000000000000000, 0x1ff0af0d95025bc3,
00C51034  mov         dword ptr [esp+58h],eax  
00C51038  mov         dword ptr [esp+5Ch],eax  
00C5103C  mov         dword ptr [esp+60h],eax  
00C51040  mov         dword ptr [esp+64h],eax  
00C51044  mov         dword ptr [esp+68h],eax  
00C51048  mov         dword ptr [esp+6Ch],eax  
		0x1fc9353df6af376b, 0x0000000000000000, 0x0000000000000000, 0x0000000000000000,
00C5104C  mov         dword ptr [esp+80h],eax  
00C51053  mov         dword ptr [esp+84h],eax  
00C5105A  mov         dword ptr [esp+88h],eax  
00C51061  mov         dword ptr [esp+8Ch],eax  
00C51068  mov         dword ptr [esp+90h],eax  
00C5106F  mov         dword ptr [esp+94h],eax  
		0x0000000000000000, 0x0000000000000000, 0x0000000000000000, 0x0000000000000000
00C51076  mov         dword ptr [esp+98h],eax  
00C5107D  mov         dword ptr [esp+9Ch],eax  
00C51084  mov         dword ptr [esp+0A0h],eax  
00C5108B  mov         dword ptr [esp+0A4h],eax  
00C51092  mov         dword ptr [esp+0A8h],eax  
00C51099  mov         dword ptr [esp+0ACh],eax  
	};
00C510A0  mov         dword ptr [esp+0B0h],eax  
00C510A7  mov         dword ptr [esp+0B4h],eax  
	double* inputs = (double*)inputs_hex;
	double norm = calc_norm_and_regulate(count, inputs, false);
00C510AE  lea         eax,[esp+38h]  
00C510B2  mov         dword ptr [esp+50h],240AA54h  
00C510BA  mov         dword ptr [esp+54h],1FEDB153h  
00C510C2  mov         dword ptr [esp+70h],95025BC3h  
00C510CA  mov         dword ptr [esp+74h],1FF0AF0Dh  
00C510D2  mov         dword ptr [esp+78h],0F6AF376Bh  
00C510DA  mov         dword ptr [esp+7Ch],1FC9353Dh  
00C510E2  call        calc_norm_and_regulate<double> (0C51130h)  
00C510E7  fst         qword ptr [esp+30h]  
	fprintf(stdout, "[2]0x%016llX:%.19lg\n", *(uint64_t*)&norm, norm);
00C510EB  mov         eax,dword ptr [esp+34h]  
00C510EF  mov         ecx,dword ptr [esp+30h]  
00C510F3  sub         esp,8  
00C510F6  fstp        qword ptr [esp]  
00C510F9  push        eax  
00C510FA  push        ecx  
00C510FB  push        offset string "[2]0x%016llX:%.19lg\n" (0C520F4h)  
00C51100  call        dword ptr [__imp____iob_func (0C5209Ch)]  
00C51106  add         eax,20h  
00C51109  push        eax  
00C5110A  call        dword ptr [__imp__fprintf (0C520A4h)]  
	return 0;
}
00C51110  mov         ecx,dword ptr [esp+0D4h]  
00C51117  add         esp,18h  
00C5111A  xor         ecx,esp  
00C5111C  xor         eax,eax  
00C5111E  call        __security_check_cookie (0C511D5h)  
00C51123  mov         esp,ebp  
00C51125  pop         ebp  
00C51126  ret  
--- ソース ファイルがありません -------------------------------------------------------------
00C51127  int         3  
00C51128  int         3  
00C51129  int         3  
00C5112A  int         3  
00C5112B  int         3  
00C5112C  int         3  
00C5112D  int         3  
00C5112E  int         3  
00C5112F  int         3  
--- c:\mingw\msys\1.0\home\root\double2\double2\double2.cpp --------------------
#include "stdafx.h"
#include <stdio.h>
#include <stdint.h>
#include <math.h>

template<typename T> static double calc_norm_and_regulate(int num, T* r, bool regulate){ // <float> for debug.
00C51130  push        ebp  
00C51131  mov         ebp,esp  
00C51133  sub         esp,10h  
	double norm = 0;
00C51136  fldz  
00C51138  add         eax,10h  
00C5113B  fstp        qword ptr [norm]  
00C5113E  mov         ecx,2  
00C51143  jmp         calc_norm_and_regulate<double>+17h (0C51147h)  
00C51145  fstp        st(0)  
	for (int i = 0; i < num; i++) {
		norm += (double)r[i] * (double)r[i];
00C51147  fld         qword ptr [eax-10h]  
00C5114A  add         eax,40h  
00C5114D  dec         ecx  
00C5114E  fld         qword ptr [eax-48h]  
00C51151  fld         qword ptr [eax-40h]  
00C51154  fld         qword ptr [eax-38h]  
00C51157  fld         qword ptr [eax-30h]  
00C5115A  fld         qword ptr [eax-28h]  
00C5115D  fld         qword ptr [eax-20h]  
00C51160  fld         qword ptr [eax-18h]  
00C51163  fstp        qword ptr [ebp-10h]  
00C51166  fld         st(6)  
00C51168  fmulp       st(7),st  
00C5116A  fxch        st(6)  
00C5116C  fadd        qword ptr [norm]  
00C5116F  fld         st(5)  
00C51171  fmulp       st(6),st  
00C51173  faddp       st(5),st  
00C51175  fld         st(3)  
00C51177  fmulp       st(4),st  
00C51179  fxch        st(4)  
00C5117B  faddp       st(3),st  
00C5117D  fld         st(1)  
00C5117F  fmulp       st(2),st  
00C51181  fxch        st(2)  
00C51183  faddp       st(1),st  
00C51185  fld         st(1)  
00C51187  fmulp       st(2),st  
00C51189  faddp       st(1),st  
00C5118B  fld         st(1)  
00C5118D  fmulp       st(2),st  
00C5118F  faddp       st(1),st  
00C51191  fld         st(1)  
00C51193  fmulp       st(2),st  
00C51195  faddp       st(1),st  
00C51197  fld         qword ptr [ebp-10h]  
00C5119A  fmul        st(0),st  
00C5119C  faddp       st(1),st  
00C5119E  fst         qword ptr [norm]  
00C511A1  jne         calc_norm_and_regulate<double>+15h (0C51145h)  
//		fprintf(stdout, "[0]0x%016llX:%.19lg\n", *(uint64_t*)&norm, norm);
	}
	fprintf(stdout, "[1]0x%016llX:%.19lg\n", *(uint64_t*)&norm, norm);
00C511A3  mov         eax,dword ptr [ebp-4]  
00C511A6  mov         ecx,dword ptr [norm]  
00C511A9  sub         esp,8  
00C511AC  fstp        qword ptr [esp]  
00C511AF  push        eax  
00C511B0  push        ecx  
00C511B1  push        offset string "[1]0x%016llX:%.19lg\n" (0C5210Ch)  
00C511B6  call        dword ptr [__imp____iob_func (0C5209Ch)]  
00C511BC  add         eax,20h  
00C511BF  push        eax  
00C511C0  call        dword ptr [__imp__fprintf (0C520A4h)]  
	norm = sqrt(norm);
00C511C6  fld         qword ptr [norm]  
00C511C9  add         esp,18h  
00C511CC  call        _CIsqrt (0C519D0h)  
	if (regulate)
		for (int i=0;i<num;i++)
			r[i] = (T)(r[i]/norm);
	return norm;
}
00C511D1  mov         esp,ebp  
00C511D3  pop         ebp  
00C511D4  ret  
