1
1

69 Коммитов

Автор SHA1 Сообщение Дата
George Bosilca
c3b73e3b46 In the begining the parent is set to comm_null. If there are no communications a segfault is generated
when ompi_mpi_finalize is called.

This commit was SVN r2756.
2004-09-19 07:13:58 +00:00
Edgar Gabriel
65e4b61ec2 fixes to make comm_join work
This commit was SVN r2745.
2004-09-17 16:28:58 +00:00
Edgar Gabriel
6f3ebd184a minor bug fixes
This commit was SVN r2744.
2004-09-17 13:16:47 +00:00
Edgar Gabriel
e14bbf5fc4 adaping some routines to use proc_find_and_add
activating name_publishing (also tested, testcode will be checked in soon).
adaping the port-stuff to the new format.

This commit was SVN r2741.
2004-09-17 10:11:22 +00:00
Edgar Gabriel
5f29fe41fa fixing a stupid bug
This commit was SVN r2711.
2004-09-16 12:16:21 +00:00
Edgar Gabriel
29110f6bc6 adapting some routines to the new interface of ompi_proc_get_namebuf etc...
This commit was SVN r2708.
2004-09-16 10:07:42 +00:00
Edgar Gabriel
d2d6379578 fixing a stupid bug in comm_nextcid: forgot to free the value in the pointer_array in case the others did not agree with my suggestion for the cid.
This commit was SVN r2631.
2004-09-13 15:14:09 +00:00
Tim Woodall
2a71e4abac fixed the local rank in comm world to be the relative rank in
the grouprather than the proceses vpid

This commit was SVN r2580.
2004-09-09 22:57:53 +00:00
Edgar Gabriel
718be11bdb fixing a problem for error handlers as discussed with Jeff a couple of weeks ago. The macros used in the MPI functions have not changed, thus the modifications should be transparent to all other functions.
This commit was SVN r2522.
2004-09-06 12:06:27 +00:00
Vishal Sahay
cfd377cdd8 Fix the length of periods_or_edges array for graph/cart.
This commit was SVN r2461.
2004-09-03 00:48:56 +00:00
Edgar Gabriel
5286e5205c remove a warning
This commit was SVN r2451.
2004-09-02 16:06:04 +00:00
Jeff Squyres
cfd5524ad5 Committing several things under one commit, but they're all at least
somewhat tied together and I'd rather have a consistent commit rather
than several smaller commits that individually break the tree:
- first cut of src/file/file.c: MPI_File handling.  More to come here.
- tweaked MPI_Info handling a bit: cause MPI_Info_f2c to invoke error
  handler if provided index is out of range (vs. returing
  MPI_INFO_NULL without invoking an error handler)
- moved general MPI MCA params off into their own .h and .c file (so
  that ompi_info can call it and therefore display MPI MCA params)
- first [abbreviated] cut of src/mca/io/base/* -- much more to come
  here; stripped down to basics for this commit
- filled in a small number of MPI_File* functions for testing purposes
- updated a bunch of doxygen docs
--> Unresolved questions about MPI_ERRORS_RETURN, MPI_ERRORS_ABORT,
    and MPI::ERRORS_THROW_EXCEPTIONS because of vagueness in MPI
    standard -- Edgar and I are discussing what to do here
--> Unresolved questions about what to do in a case like this:
      MPI_File_open(..., &file);
      MPI_File_close(&file);
      MPI_File_read(..., &file);
    because MPI-2:9.7 says that the default error handler on MPI_File
    handles is MPI_ERRORS_RETURN -- we can't even print a warning
    here!  This certainly violates the Law of Least Astonishment for
    MPI users (who certainly expect MPI functions that fail to
    complain loudly and to abort by default).

This commit was SVN r2136.
2004-08-14 01:56:05 +00:00
Edgar Gabriel
1ca0115ff7 adding in finalize a verification, whether we still have some communicators there...which should not happen in a correct MPI code.
This commit was SVN r2124.
2004-08-13 18:55:07 +00:00
Edgar Gabriel
573b4ea950 adding a check whether the f_to_c_index is initialized in the destructor for consistency reasons.
removing the warning in comm_split_f pointed out be the 64bit architecture. Actually, I wonder why g77 did not detect that, since this was a real bug and not just a warning :-)

This commit was SVN r2113.
2004-08-13 13:31:26 +00:00
Tim Woodall
a2bc814a08 OOB API changes:
- removed send_hton/recv_ntoh routines as we now have send_packed/recv_packed 
- removed constness from apis
- adding flag (in work) to allow recv to allocate and return recv buffer
- updated edgars communicator code to use pack routines rather than ntoh routines

This commit was SVN r2095.
2004-08-12 22:41:42 +00:00
Edgar Gabriel
de00ca3429 and introduced immediatly a new typo :-)
This commit was SVN r1990.
2004-08-09 22:06:07 +00:00
Edgar Gabriel
ef0079f0d6 fixing a typo in the comm-destructor
This commit was SVN r1989.
2004-08-09 22:04:55 +00:00
Edgar Gabriel
0debc6e9be using the name_server.compare function to make decision who goes first
in intercomm_merge.

This commit was SVN r1967.
2004-08-08 19:19:05 +00:00
Edgar Gabriel
17a929c9dd activating comm_split for inter-communicators. It seems to work as well...
This commit was SVN r1957.
2004-08-07 21:15:00 +00:00
Edgar Gabriel
ba165b3d8a initializing two variables used in a dummy allreduce
This commit was SVN r1926.
2004-08-06 15:46:44 +00:00
Edgar Gabriel
b8d6fd5d50 introducing a 'hidden' communicator flag. The communicators marked hidden will not be exported to totalview (e.g. internal communicators of the MagPIe coll framework).
This commit was SVN r1925.
2004-08-06 14:33:23 +00:00
Edgar Gabriel
6a8bebacd4 bug fix: set comm->c_topo to NULL in the allocator as well, for debug
purposes (although it did not cause any problems) we memset the
    c_coll structure to zero as well.
enabling comm_create for inter-communicators

This commit was SVN r1919.
2004-08-05 22:48:47 +00:00
Edgar Gabriel
2e43e4980e a couple of changes:
- because we had the scenario, that fragments for a communicator, which was not 
   not yet set up on all procs, arrived and caused problem, we introduced
   a comm_activate function call, which executes a kind of barrier (using
   the allreduce functions used for the comm_cid allocation).
   Setting up the coll-component has moved *after* this barrier, since 
   some coll-modules (e.g. the MagPIe component) might want to communicate
   using this communicator already (e.g. a comm_split).
-  adding a new file comm_dyn.c, which basically abstracts the required functionality
   for connect-accept, and therefore is the 'magic' code (from the MPI point of view)
   for all dynamically created communicators.

This commit was SVN r1900.
2004-08-05 16:31:30 +00:00
Edgar Gabriel
167e046ee0 sorry, deactivating the comm-mutex to avoid problems.
This commit was SVN r1878.
2004-08-04 19:55:45 +00:00
Edgar Gabriel
177d6ddae2 adding a mutex for locking name and attributes in a communicator.
Adding a functions abstracting the setting of the name. 

This commit was SVN r1875.
2004-08-04 19:46:29 +00:00
Edgar Gabriel
1ab1721c6c making ompi_comm_get_rprocs use the new ompi_proc_get_namebuf-* functions.
This commit was SVN r1870.
2004-08-04 17:06:33 +00:00
Edgar Gabriel
20a512a9b7 restructuring some of the communicator code.
with a couple of internal tricks, intercomm_create works now.

This commit was SVN r1855.
2004-08-03 22:07:45 +00:00
Jeff Squyres
eb8cba98af - massive change for module<-->component name fixes throughout the
code base.
  - many (most) mca type names have "component" or "module" in them,
    as relevant, just to further distinguish the difference between
    component data/actions and module data/actions.  All developers
    are encouraged to perpetuate this convention when you create
    types that are specific to a framework, component, or module
  - did very little to entire framework (just the basics to make it
    compile) because it's just about to be almost entirely replaced
  - ditto for io / romio
  - did not work on elan or ib components; have to commit and then
    convert those on a different machine with the right libraries and
    headers
- renamed a bunch of *_module.c files to *_component.c and *module*c
  to *component*c (a few still remain, e.g., ptl/ib, ptl/elan, etc.)
- modified autogen/configure/build process to match new filenames
  (e.g., output static-components.h instead of static-modules.h)
- removed DOS-style cr/lf stuff in ns/ns.h
- added newline to end of file src/util/numtostr.h
- removed some redundant error checking in the top-level topo
  functions
- added a few {} here and there where people "forgot" to put them in
  for 1 line blocks ;-)
- removed a bunch of MPI_* types from mca header files (replaced with
  corresponding ompi_* types)
- all the ptl components had version numbers in their structs; removed
- converted a few more elements in the MCA base to use the OBJ
  interface -- removed some old manual reference counting kruft

This commit was SVN r1830.
2004-08-02 00:24:22 +00:00
Prabhanjan Kambadur
cae7d0afcb Changing a lot of stuff in topo. This commit is just the intergration
of what has been done in tmp/anju-topo-work branch. For more detailed 
information on the commits, please see those logs

This commit was SVN r1787.
2004-07-20 22:21:47 +00:00
Edgar Gabriel
e190c49722 - intra-comms tested, several minor bugs fixed
- cid allocation for intra-comms is now enabled and working

This commit was SVN r1750.
2004-07-15 20:55:15 +00:00
George Bosilca
81feeca5ed Delte the attribute on the correct object.
This commit was SVN r1728.
2004-07-14 19:33:07 +00:00
Jeff Squyres
16f7e613f6 Have DUP pass a preferred coll module when making the new
communicator. 

This commit was SVN r1696.
2004-07-13 20:50:59 +00:00
Jeff Squyres
d1c5e93cd4 Changes to accomodate procid->vpid and to move away from accessing the
vpid directly.  Instead, use the ompi_name_server.get_vpid() (and
friends) accessor functions from the selected ns module.

This fixes compile issues, but still leaves linker issues -- Ralph
will be committing a fix for those shortly.

This commit was SVN r1592.
2004-07-08 14:48:34 +00:00
Tim Woodall
165d4f8841 merge of oob/rte changes from rte branch
This commit was SVN r1527.
2004-07-01 14:49:54 +00:00
Jeff Squyres
a5a712b31f Lots of changes in this commit, mostly having to do with the first
real commit of the collectives.  MPI_SCAN and MPI_EXSCAN are still not
implemented, but lots of other things are in the critical path and
holding up other people, so it's ok to commit without them:

- better checks for sizes in configure, and add defaults for fortran
  sizes if we don't have a fortran compiler
- fix some logic that was accidentally broken for size checks for the
  file type offset_t
- add some C equivalent types for fortran's complex and double complex
  (for use in internal reduction/op functions)
- additionals and slight reorganization of ompi_mpi_init()
  ompi_mpi_finalize()
- fully implement all top-level MPI collective calls, including all
  param checking for both intra- and inter-communicators (woof)
- change the communicator_t type for stuff that we need in coll, and
  update all references throughout the code base to match
- all kinds of updates to the coll framework base
- next cut of the basic coll module -- has all intracommunicator
  collectives implemented except scan and exscan (see note above).
  All intercommunicator functions return ERR_NOT_IMPLEMENTED.
- MPI_Op is a fixed implementation -- not component-ized yet.  So
  there are generic C loops for all implementations.

This commit was SVN r1491.
2004-06-29 00:02:25 +00:00
Tim Woodall
2ce7ca725b - cleanup of some of the c bindings
- for threaded case - cleanup event libraries progress thread
- cleanup of request handling for persistent sends
- added support for buffered sends

This commit was SVN r1461.
2004-06-24 16:47:00 +00:00
Edgar Gabriel
994c20c191 bug fix, sorry!
This commit was SVN r1413.
2004-06-18 17:19:58 +00:00
Edgar Gabriel
392115b9d5 adding the correct calling of attr-copy and attr-delete functions to comm_set and comm_free.
This commit was SVN r1411.
2004-06-18 15:29:50 +00:00
Jeff Squyres
5e5042613f *really* rename the project to "openmpi". :-)
This commit was SVN r1370.
2004-06-17 18:21:08 +00:00
Edgar Gabriel
deec2c1435 preparing the comm_cid allocation routine for dynamic process management
This commit was SVN r1336.
2004-06-16 22:37:03 +00:00
Edgar Gabriel
2598915dc7 adding functions for handling the name publishing. Currently ifdefed out,
just blank routines are provided for keeping the linker happy.

This commit was SVN r1334.
2004-06-16 21:34:42 +00:00
Edgar Gabriel
f8294ab099 extracting the creation of comm_cid from the comm_set routine.
The reason is, that we had to pass four arguments to comm_sdet, which were just passed to comm_cid. However, for the dynamic case, even these four arguments are not enough. So I extracted it. A typical sequence for a comm-creation will therefore be:

 newcomm = ompi_comm_set (...);
 ompi_comm_nextcid (newcomm, oldcomm,...);

This commit was SVN r1312.
2004-06-16 15:40:52 +00:00
Edgar Gabriel
bdef2b4a09 fixed the prototype of ompi_comm_dump
- added a function for implementing an allgather on the local_comm for inter-communicators. Will just be used from MPI_Comm_split for inter-communicators

This commit was SVN r1283.
2004-06-15 21:29:29 +00:00
Edgar Gabriel
df91640da6 just minor modifications to match the modifications in the group-struct.
This commit was SVN r1258.
2004-06-15 00:09:40 +00:00
Edgar Gabriel
62f6f75b7c renaming a file for convinience reasons
This commit was SVN r1207.
2004-06-08 22:10:06 +00:00
David Daniel
2f96ba71fe renaming files
This commit was SVN r1192.
2004-06-07 15:40:19 +00:00
David Daniel
563ac2a338 First pass of lam -> ompi conversion
This commit was SVN r1191.
2004-06-07 15:33:53 +00:00
Edgar Gabriel
bc9ac9b7b1 fixed the reference count stuff detected by George.
Modification of lam_comm_destruct and lam_comm_finalize.

Tested with some simple pt2pt tests, and it seems to work.

Since just some very minor modifications, code has been reviewed locally by George.

This commit was SVN r1185.
2004-06-03 21:23:42 +00:00
George Bosilca
e71623f6f9 Correctly handle the ref count for the 3 predefined communicators.
This commit was SVN r1177.
2004-06-01 04:21:39 +00:00
Vishal Sahay
196020d6a0 Init attribute for initialized comms
This commit was SVN r1173.
2004-05-30 16:50:41 +00:00