Timers in xtr_dl

new-context
Salvatore Filippone 5 years ago
parent 7de9318aa9
commit 7fa4eae8c9

@ -127,6 +127,7 @@ subroutine psi_i_extract_dep_list(ictxt,is_bld,is_upd,desc_str,dep_list,&
use psb_error_mod use psb_error_mod
use psb_desc_mod use psb_desc_mod
use psb_sort_mod use psb_sort_mod
use psb_timers_mod
implicit none implicit none
#ifdef MPI_H #ifdef MPI_H
include 'mpif.h' include 'mpif.h'
@ -148,6 +149,8 @@ subroutine psi_i_extract_dep_list(ictxt,is_bld,is_upd,desc_str,dep_list,&
integer(psb_ipk_) :: debug_level, debug_unit integer(psb_ipk_) :: debug_level, debug_unit
integer(psb_mpk_) :: iictxt, icomm, me, np, minfo integer(psb_mpk_) :: iictxt, icomm, me, np, minfo
logical, parameter :: dist_symm_list=.false., print_dl=.false., profile=.true. logical, parameter :: dist_symm_list=.false., print_dl=.false., profile=.true.
logical, parameter :: do_timings=.false.
integer(psb_ipk_), save :: idx_phase1=-1, idx_phase2=-1, idx_phase3=-1
character name*20 character name*20
name='psi_extrct_dl' name='psi_extrct_dl'
@ -156,8 +159,16 @@ subroutine psi_i_extract_dep_list(ictxt,is_bld,is_upd,desc_str,dep_list,&
debug_level = psb_get_debug_level() debug_level = psb_get_debug_level()
iictxt = ictxt iictxt = ictxt
info = psb_success_ info = psb_success_
if ((do_timings).and.(idx_phase1==-1)) &
& idx_phase1 = psb_get_timer_idx("PSI_XTR_DL: phase1 ")
if ((do_timings).and.(idx_phase2==-1)) &
& idx_phase2 = psb_get_timer_idx("PSI_XTR_DL: phase2")
!!$ if ((do_timings).and.(idx_phase3==-1)) &
!!$ & idx_phase3 = psb_get_timer_idx("PSI_XTR_DL: phase3")
call psb_info(iictxt,me,np) call psb_info(iictxt,me,np)
if (do_timings) call psb_tic(idx_phase1)
allocate(itmp(2*np+1),length_dl(0:np),stat=info) allocate(itmp(2*np+1),length_dl(0:np),stat=info)
if (info /= psb_success_) then if (info /= psb_success_) then
info=psb_err_alloc_dealloc_ info=psb_err_alloc_dealloc_
@ -252,6 +263,9 @@ subroutine psi_i_extract_dep_list(ictxt,is_bld,is_upd,desc_str,dep_list,&
endif endif
length_dl(me)=pointer_dep_list-1 length_dl(me)=pointer_dep_list-1
if (do_timings) call psb_toc(idx_phase1)
if (do_timings) call psb_tic(idx_phase2)
if (dist_symm_list) then if (dist_symm_list) then
call psb_realloc(length_dl(me),itmp,info) call psb_realloc(length_dl(me),itmp,info)
call psi_symm_dep_list(itmp,ictxt,info) call psi_symm_dep_list(itmp,ictxt,info)
@ -367,6 +381,7 @@ subroutine psi_i_extract_dep_list(ictxt,is_bld,is_upd,desc_str,dep_list,&
end if end if
call psb_barrier(ictxt) call psb_barrier(ictxt)
end if end if
if (do_timings) call psb_toc(idx_phase2)
if ((profile).and.(me==0)) then if ((profile).and.(me==0)) then
block block
integer(psb_ipk_) :: dlmax, dlavg integer(psb_ipk_) :: dlmax, dlavg

Loading…
Cancel
Save