main Program

Uses

  • program~~main~20~~UsesGraph program~main~20 main module~fakeextdatamod_server FakeExtDataMod_server program~main~20->module~fakeextdatamod_server module~mapl_exceptionhandling MAPL_ExceptionHandling program~main~20->module~mapl_exceptionhandling module~pfio pFIO program~main~20->module~pfio module~server_demo_cli server_demo_CLI program~main~20->module~server_demo_cli mpi mpi program~main~20->mpi

Calls

program~~main~20~~CallsGraph program~main~20 main connect_to_client connect_to_client program~main~20->connect_to_client mpi_comm_rank mpi_comm_rank program~main~20->mpi_comm_rank mpi_comm_size mpi_comm_size program~main~20->mpi_comm_size mpi_comm_split mpi_comm_split program~main~20->mpi_comm_split mpi_finalize mpi_finalize program~main~20->mpi_finalize mpi_init_thread mpi_init_thread program~main~20->mpi_init_thread none~finalize~14 FakeExtData%finalize program~main~20->none~finalize~14 none~init~9 FakeExtData%init program~main~20->none~init~9 none~run~18 FakeExtData%run program~main~20->none~run~18 proc~mapl_abort MAPL_abort program~main~20->proc~mapl_abort proc~mapl_verify MAPL_Verify program~main~20->proc~mapl_verify proc~process_command_line~6 process_command_line program~main~20->proc~process_command_line~6 publish publish program~main~20->publish start start program~main~20->start none~terminate ClientThread%terminate none~finalize~14->none~terminate none~init~9->mpi_comm_rank none~init~9->mpi_comm_size none~init~9->proc~mapl_verify at at none~init~9->at connect_to_server connect_to_server none~init~9->connect_to_server none~get_dimensions FileMetadata%get_dimensions none~init~9->none~get_dimensions none~run~18->at none~add_ext_collection ClientThread%add_ext_collection none~run~18->none~add_ext_collection none~done_prefetch ClientThread%done_prefetch none~run~18->none~done_prefetch none~prefetch_data ClientThread%prefetch_data none~run~18->none~prefetch_data mpi_abort mpi_abort proc~mapl_abort->mpi_abort proc~mapl_throw_exception MAPL_throw_exception proc~mapl_verify->proc~mapl_throw_exception interface~mapl_assert MAPL_Assert proc~process_command_line~6->interface~mapl_assert push_back push_back proc~process_command_line~6->push_back

Variables

Type Attributes Name Initial
integer, parameter :: CLIENT_COLOR = 2
integer, parameter :: SERVER_COLOR = 1
integer :: color
integer :: comm
integer :: ierror
integer :: key
integer :: npes
integer :: provided
integer :: rank
integer :: rc
integer :: status
class(AbstractDirectoryService), pointer :: d_s => null()
class(BaseServer), allocatable :: s
type(CommandLineOptions) :: options
type(FakeExtData), target :: extData

Source Code

program main
   use mpi
   use pFIO
   use server_demo_CLI
   use FakeExtDataMod_server
   use MAPL_ExceptionHandling
   implicit none

   integer :: rank, npes, ierror, provided
   integer :: status, color, key, rc
   class(BaseServer),allocatable :: s


   type (CommandLineOptions) :: options
   integer, parameter :: SERVER_COLOR = 1
   integer, parameter :: CLIENT_COLOR = 2

   integer :: comm
!C$   integer :: num_threads
   type (FakeExtData), target :: extData
   class(AbstractDirectoryService), pointer :: d_s=>null()

   call MPI_init_thread(MPI_THREAD_MULTIPLE, provided, ierror)
   _VERIFY(ierror)
   call MPI_Comm_rank(MPI_COMM_WORLD, rank, ierror)
   _VERIFY(ierror)
   call MPI_Comm_size(MPI_COMM_WORLD, npes, ierror)
   _VERIFY(ierror)

   call process_command_line(options, rc=status)


   if (rank < options%npes_server) then
      color = SERVER_COLOR
   else
      color = CLIENT_COLOR
   end if
   key = 0

   call MPI_Comm_split(MPI_COMM_WORLD, color, key, comm, ierror)
   _VERIFY(ierror)

!C$   num_threads = 20
   allocate(d_s, source = DirectoryService(MPI_COMM_WORLD))

   if (color == SERVER_COLOR) then
      if(trim(options%server_type) == 'mpi') then
         allocate(s, source=MpiServer(comm, 'i_server'))
         call d_s%publish(PortInfo('i_server', s),s)
         call d_s%connect_to_client('i_server', s)
         print*, "using MpiServer"
      else if(trim(options%server_type) == 'openmp') then
!C$         call omp_set_num_threads(num_threads)
!C$         allocate(s, source=OpenMPServer(comm,d_s))
!C$         print*, "using OpenMPServer"
      else
         print*, options%server_type // '  not implemented'
         stop
      endif    
      call s%start()
   else ! client
      call extData%init(options, comm, d_s)
      call extData%run(step=1)
      call extData%run(step=2)
      call extData%finalize()

      !print*,"terminate_servers"
      !call global_directory_service%terminate_servers(comm)
   end if

   call MPI_finalize(ierror)

end program main