mirror of
https://gitlab.com/scemama/irpf90.git
synced 2024-12-21 11:53:32 +01:00
Added irp_rdtsc to ninja
This commit is contained in:
parent
3729312876
commit
f68f16fcc3
@ -369,8 +369,8 @@ def run():
|
|||||||
l_common_s += [ "irp_locks.irp.F90" ]
|
l_common_s += [ "irp_locks.irp.F90" ]
|
||||||
|
|
||||||
if command_line.do_profile:
|
if command_line.do_profile:
|
||||||
l_common_o += [ "irp_profile.irp.o", "rdtsc.o" ]
|
l_common_o += [ "irp_profile.irp.o", "irp_rdtsc.o" ]
|
||||||
l_common_s += [ "irp_profile.irp.F90", "rdtsc.c" ]
|
l_common_s += [ "irp_profile.irp.F90", "irp_rdtsc.c" ]
|
||||||
|
|
||||||
l_common_o = map(dress,l_common_o) + map(lambda x: dress(x,in_root=True), OBJ)
|
l_common_o = map(dress,l_common_o) + map(lambda x: dress(x,in_root=True), OBJ)
|
||||||
l_common_s = map(dress,l_common_s) + map(lambda x: dress(x,in_root=True), SRC)
|
l_common_s = map(dress,l_common_s) + map(lambda x: dress(x,in_root=True), SRC)
|
||||||
|
@ -45,19 +45,19 @@ import subprocess
|
|||||||
import tempfile
|
import tempfile
|
||||||
import os
|
import os
|
||||||
import threading
|
import threading
|
||||||
|
from irpf90_t import irpdir
|
||||||
|
|
||||||
def build_rdtsc():
|
def build_rdtsc():
|
||||||
file,filename = tempfile.mkstemp()
|
filename = irpdir+"irp_rdtsc.c"
|
||||||
filename += ".c"
|
|
||||||
file = open(filename,'w')
|
file = open(filename,'w')
|
||||||
file.write(rdtsc)
|
file.write(rdtsc)
|
||||||
file.close()
|
file.close()
|
||||||
def t():
|
# def t():
|
||||||
p = subprocess.Popen(["gcc","-O2",filename,"-c","-o","irp_rdtsc.o"])
|
# p = subprocess.Popen(["gcc","-O2",filename,"-c","-o","irp_rdtsc.o"])
|
||||||
p.communicate()
|
# p.communicate()
|
||||||
os.remove(filename)
|
# os.remove(filename)
|
||||||
|
#
|
||||||
threading.Thread(target=t).start()
|
# threading.Thread(target=t).start()
|
||||||
|
|
||||||
def build_module():
|
def build_module():
|
||||||
from variables import variables
|
from variables import variables
|
||||||
@ -104,11 +104,10 @@ subroutine irp_init_timer
|
|||||||
double precision :: irp_rdtsc, t0
|
double precision :: irp_rdtsc, t0
|
||||||
irp_profile = 0.d0
|
irp_profile = 0.d0
|
||||||
irp_rdtsc_shift = 0.d0
|
irp_rdtsc_shift = 0.d0
|
||||||
do i=1,1000
|
do i=1,1000000
|
||||||
t0 = irp_rdtsc()
|
t0 = irp_rdtsc()
|
||||||
irp_rdtsc_shift = irp_rdtsc_shift + (irp_rdtsc()-t0)
|
|
||||||
enddo
|
enddo
|
||||||
irp_rdtsc_shift = 1.d-3*irp_rdtsc_shift
|
irp_rdtsc_shift = 1.d-6*(irp_rdtsc()-t0)
|
||||||
%(text)s
|
%(text)s
|
||||||
end
|
end
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user