1 2 /* 3 We define the memory operations here. The reason we just do not use 4 the standard memory routines in the PETSc code is that on some machines 5 they are broken. 6 7 */ 8 #include <petsc/private/petscimpl.h> /*I "petscsys.h" I*/ 9 #include <petscbt.h> 10 #include <../src/sys/utils/ftn-kernels/fcopy.h> 11 12 /*@ 13 PetscMemcmp - Compares two byte streams in memory. 14 15 Not Collective 16 17 Input Parameters: 18 + str1 - Pointer to the first byte stream 19 . str2 - Pointer to the second byte stream 20 - len - The length of the byte stream 21 (both str1 and str2 are assumed to be of length len) 22 23 Output Parameters: 24 . e - `PETSC_TRUE` if equal else `PETSC_FALSE`. 25 26 Level: intermediate 27 28 Notes: 29 `PetscArraycmp()` is preferred 30 31 This routine is anologous to `memcmp()` with additional error checking 32 33 .seealso: `PetscMemcpy()`, `PetscMemcmp()`, `PetscArrayzero()`, `PetscMemzero()`, `PetscArraycmp()`, `PetscArraycpy()`, `PetscStrallocpy()`, 34 `PetscArraymove()` 35 @*/ 36 PetscErrorCode PetscMemcmp(const void *str1, const void *str2, size_t len, PetscBool *e) 37 { 38 if (!len) { 39 // if e is a bad ptr I guess we just die here then? 40 *e = PETSC_TRUE; 41 return 0; 42 } 43 44 PetscFunctionBegin; 45 PetscValidPointer(str1, 1); 46 PetscValidPointer(str2, 2); 47 PetscValidBoolPointer(e, 4); 48 *e = memcmp((char *)str1, (char *)str2, len) ? PETSC_FALSE : PETSC_TRUE; 49 PetscFunctionReturn(0); 50 } 51 52 #if defined(PETSC_HAVE_HWLOC) 53 #include <petsc/private/petscimpl.h> 54 #include <hwloc.h> 55 56 /*@C 57 PetscProcessPlacementView - display the MPI rank placement by core 58 59 Input Parameter: 60 . viewer - ASCII viewer to display the results on 61 62 Level: intermediate 63 64 Note: 65 Requires that PETSc be installed with hwloc, for example using --download-hwloc 66 @*/ 67 PetscErrorCode PetscProcessPlacementView(PetscViewer viewer) 68 { 69 PetscBool isascii; 70 PetscMPIInt rank; 71 hwloc_bitmap_t set; 72 hwloc_topology_t topology; 73 74 PetscFunctionBegin; 75 PetscValidHeaderSpecific(viewer, PETSC_VIEWER_CLASSID, 1); 76 PetscCall(PetscObjectTypeCompare((PetscObject)viewer, PETSCVIEWERASCII, &isascii)); 77 PetscCheck(isascii, PetscObjectComm((PetscObject)viewer), PETSC_ERR_SUP, "Only ASCII viewer is supported"); 78 79 PetscCallMPI(MPI_Comm_rank(MPI_COMM_WORLD, &rank)); 80 hwloc_topology_init(&topology); 81 hwloc_topology_load(topology); 82 set = hwloc_bitmap_alloc(); 83 84 PetscCallExternal(hwloc_get_proc_cpubind, topology, getpid(), set, HWLOC_CPUBIND_PROCESS); 85 PetscCall(PetscViewerASCIIPushSynchronized(viewer)); 86 PetscCall(PetscViewerASCIISynchronizedPrintf(viewer, "MPI rank %d Process id: %d coreid %d\n", rank, getpid(), hwloc_bitmap_first(set))); 87 PetscCall(PetscViewerFlush(viewer)); 88 hwloc_bitmap_free(set); 89 hwloc_topology_destroy(topology); 90 PetscFunctionReturn(0); 91 } 92 #endif 93