Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Update attr tests
[simgrid.git] / teshsuite / smpi / mpich3-test / attr / attrerrcomm.c
index 9384dd4..a8947bd 100644 (file)
 #include "mpi.h"
 #include "mpitest.h"
 
-int test_communicators ( void );
-void abort_msg ( const char *, int );
-int copybomb_fn ( MPI_Comm, int, void *, void *, void *, int * );
-int deletebomb_fn ( MPI_Comm, int, void *, void * );
+int test_communicators(void);
+void abort_msg(const char *, int);
+int copybomb_fn(MPI_Comm, int, void *, void *, void *, int *);
+int deletebomb_fn(MPI_Comm, int, void *, void *);
 
-int main( int argc, char **argv )
+int main(int argc, char **argv)
 {
     int errs;
-    MTest_Init( &argc, &argv );
+    MTest_Init(&argc, &argv);
     errs = test_communicators();
-    MTest_Finalize( errs );
+    MTest_Finalize(errs);
     MPI_Finalize();
     return 0;
 }
 
-/* 
- * MPI 1.2 Clarification: Clarification of Error Behavior of 
- *                        Attribute Callback Functions 
+/*
+ * MPI 1.2 Clarification: Clarification of Error Behavior of
+ *                        Attribute Callback Functions
  * Any return value other than MPI_SUCCESS is erroneous.  The specific value
  * returned to the user is undefined (other than it can't be MPI_SUCCESS).
  * Proposals to specify particular values (e.g., user's value) failed.
  */
 /* Return an error as the value */
-int copybomb_fn( MPI_Comm oldcomm, int keyval, void *extra_state,
-               void *attribute_val_in, void *attribute_val_out, int *flag)
+int copybomb_fn(MPI_Comm oldcomm, int keyval, void *extra_state,
+                void *attribute_val_in, void *attribute_val_out, int *flag)
 {
     /* Note that if (sizeof(int) < sizeof(void *), just setting the int
-       part of attribute_val_out may leave some dirty bits
-    */
+     * part of attribute_val_out may leave some dirty bits
+     */
     *flag = 1;
     return MPI_ERR_OTHER;
 }
@@ -52,91 +52,89 @@ int copybomb_fn( MPI_Comm oldcomm, int keyval, void *extra_state,
 /* Set delete flag to 1 to allow the attribute to be deleted */
 static int delete_flag = 0;
 
-int deletebomb_fn( MPI_Comm comm, int keyval, void *attribute_val, 
-                  void *extra_state)
+int deletebomb_fn(MPI_Comm comm, int keyval, void *attribute_val, void *extra_state)
 {
-    if (delete_flag) return MPI_SUCCESS;
+    if (delete_flag)
+        return MPI_SUCCESS;
     return MPI_ERR_OTHER;
 }
 
-void abort_msg( const char *str, int code )
+void abort_msg(const char *str, int code)
 {
-    fprintf( stderr, "%s, err = %d\n", str, code );
-    MPI_Abort( MPI_COMM_WORLD, code );
-    exit(code);
+    fprintf(stderr, "%s, err = %d\n", str, code);
+    MPI_Abort(MPI_COMM_WORLD, code);
 }
 
-int test_communicators( void )
+int test_communicators(void)
 {
     MPI_Comm dup_comm_world, d2;
     int world_rank, world_size, key_1;
     int err, errs = 0;
     MPI_Aint value;
 
-    MPI_Comm_rank( MPI_COMM_WORLD, &world_rank );
-    MPI_Comm_size( MPI_COMM_WORLD, &world_size );
+    MPI_Comm_rank(MPI_COMM_WORLD, &world_rank);
+    MPI_Comm_size(MPI_COMM_WORLD, &world_size);
 #ifdef DEBUG
     if (world_rank == 0) {
-       printf( "*** Attribute copy/delete return codes ***\n" );
+        printf("*** Attribute copy/delete return codes ***\n");
     }
 #endif
 
-    MPI_Comm_dup( MPI_COMM_WORLD, &dup_comm_world );
-    MPI_Barrier( dup_comm_world );
+    MPI_Comm_dup(MPI_COMM_WORLD, &dup_comm_world);
+    MPI_Barrier(dup_comm_world);
 
-    MPI_Errhandler_set( dup_comm_world, MPI_ERRORS_RETURN );
+    MPI_Errhandler_set(dup_comm_world, MPI_ERRORS_RETURN);
 
-    value = - 11;
-    if ((err=MPI_Comm_create_keyval( copybomb_fn, deletebomb_fn, &key_1, &value )))
-       abort_msg( "Keyval_create", err );
+    value = -11;
+    if ((err = MPI_Comm_create_keyval(copybomb_fn, deletebomb_fn, &key_1, &value)))
+        abort_msg("Keyval_create", err);
 
-    err = MPI_Comm_set_attr( dup_comm_world, key_1, (void *) (MPI_Aint) world_rank );
+    err = MPI_Comm_set_attr(dup_comm_world, key_1, (void *) (MPI_Aint) world_rank);
     if (err) {
-       errs++;
-       printf( "Error with first put\n" );
+        errs++;
+        printf("Error with first put\n");
     }
 
-    err = MPI_Comm_set_attr( dup_comm_world, key_1, (void *) (MPI_Aint) (2*world_rank) );
+    err = MPI_Comm_set_attr(dup_comm_world, key_1, (void *) (MPI_Aint) (2 * world_rank));
     if (err == MPI_SUCCESS) {
-       errs++;
-       printf( "delete function return code was MPI_SUCCESS in put\n" );
+        errs++;
+        printf("delete function return code was MPI_SUCCESS in put\n");
     }
 
     /* Because the attribute delete function should fail, the attribute
-       should *not be removed* */
-    err = MPI_Comm_delete_attr( dup_comm_world, key_1 );
+     * should *not be removed* */
+    err = MPI_Comm_delete_attr(dup_comm_world, key_1);
     if (err == MPI_SUCCESS) {
-       errs++;
-       printf( "delete function return code was MPI_SUCCESS in delete\n" );
+        errs++;
+        printf("delete function return code was MPI_SUCCESS in delete\n");
     }
-    
-    err = MPI_Comm_dup( dup_comm_world, &d2 );
+
+    err = MPI_Comm_dup(dup_comm_world, &d2);
     if (err == MPI_SUCCESS) {
-       errs++;
-       printf( "copy function return code was MPI_SUCCESS in dup\n" );
+        errs++;
+        printf("copy function return code was MPI_SUCCESS in dup\n");
     }
     if (err != MPI_ERR_OTHER) {
-       int lerrclass;
-       MPI_Error_class( err, &lerrclass );
-       if (lerrclass != MPI_ERR_OTHER) {
-           errs++;
-           printf( "dup did not return an error code of class ERR_OTHER; " );
-           printf( "err = %d, class = %d\n", err, lerrclass );
-       }
+        int lerrclass;
+        MPI_Error_class(err, &lerrclass);
+        if (lerrclass != MPI_ERR_OTHER) {
+            errs++;
+            printf("dup did not return an error code of class ERR_OTHER; ");
+            printf("err = %d, class = %d\n", err, lerrclass);
+        }
     }
 #ifndef USE_STRICT_MPI
     /* Another interpretation is to leave d2 unchanged on error */
     if (err && d2 != MPI_COMM_NULL) {
-       errs++;
-       printf( "dup did not return MPI_COMM_NULL on error\n" );
+        errs++;
+        printf("dup did not return MPI_COMM_NULL on error\n");
     }
 #endif
 
     delete_flag = 1;
-    MPI_Comm_free( &dup_comm_world );
+    MPI_Comm_free(&dup_comm_world);
 
-    MPI_Comm_free_keyval( &key_1 );
+    MPI_Comm_free_keyval(&key_1);
 
     return errs;
 }
-