xref: /petsc/src/sys/utils/memc.c (revision 89669be4d29968dc8d4c19ce1b69194a6a561ea4)
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    Note:
29    PetscArraycmp() is preferred
30    This routine is anologous to memcmp()
31 
32 .seealso: `PetscMemcpy()`, `PetscMemcmp()`, `PetscArrayzero()`, `PetscMemzero()`, `PetscArraycmp()`, `PetscArraycpy()`, `PetscStrallocpy()`,
33           `PetscArraymove()`
34 @*/
35 PetscErrorCode PetscMemcmp(const void *str1, const void *str2, size_t len, PetscBool *e)
36 {
37   if (!len) {
38     // if e is a bad ptr I guess we just die here then?
39     *e = PETSC_TRUE;
40     return 0;
41   }
42 
43   PetscFunctionBegin;
44   PetscValidPointer(str1,1);
45   PetscValidPointer(str2,2);
46   PetscValidBoolPointer(e,4);
47   *e = memcmp((char*)str1,(char*)str2,len) ? PETSC_FALSE : PETSC_TRUE;
48   PetscFunctionReturn(0);
49 }
50 
51 #if defined(PETSC_HAVE_HWLOC)
52 #include <petsc/private/petscimpl.h>
53 #include <hwloc.h>
54 
55 /*@C
56      PetscProcessPlacementView - display the MPI process placement by core
57 
58   Input Parameter:
59 .   viewer - ASCII viewer to display the results on
60 
61   Level: intermediate
62 
63   Notes:
64     Requires that PETSc be installed with hwloc, for example using --download-hwloc
65 @*/
66 PetscErrorCode PetscProcessPlacementView(PetscViewer viewer)
67 {
68   PetscBool        isascii;
69   PetscMPIInt      rank;
70   hwloc_bitmap_t   set;
71   hwloc_topology_t topology;
72 
73   PetscFunctionBegin;
74   PetscValidHeaderSpecific(viewer,PETSC_VIEWER_CLASSID,1);
75   PetscCall(PetscObjectTypeCompare((PetscObject)viewer,PETSCVIEWERASCII,&isascii));
76   PetscCheck(isascii,PetscObjectComm((PetscObject)viewer),PETSC_ERR_SUP,"Only ASCII viewer is supported");
77 
78   PetscCallMPI(MPI_Comm_rank(MPI_COMM_WORLD,&rank));
79   hwloc_topology_init ( &topology);
80   hwloc_topology_load ( topology);
81   set = hwloc_bitmap_alloc();
82 
83   PetscStackCallStandard(hwloc_get_proc_cpubind,topology, getpid(), set, HWLOC_CPUBIND_PROCESS);
84   PetscCall(PetscViewerASCIIPushSynchronized(viewer));
85   PetscCall(PetscViewerASCIISynchronizedPrintf(viewer,"MPI rank %d Process id: %d coreid %d\n",rank,getpid(),hwloc_bitmap_first(set)));
86   PetscCall(PetscViewerFlush(viewer));
87   hwloc_bitmap_free(set);
88   hwloc_topology_destroy(topology);
89   PetscFunctionReturn(0);
90 }
91 #endif
92