A
lgorithmique
N
umérique
D
istribuée
Public GIT Repository
projects
/
simgrid.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
try to stabilize gcc with previous fixes
[simgrid.git]
/
src
/
kernel
/
activity
/
ActivityImpl.hpp
diff --git
a/src/kernel/activity/ActivityImpl.hpp
b/src/kernel/activity/ActivityImpl.hpp
index
94b8590
..
24f6e48
100644
(file)
--- a/
src/kernel/activity/ActivityImpl.hpp
+++ b/
src/kernel/activity/ActivityImpl.hpp
@@
-1,4
+1,4
@@
-/* Copyright (c) 2007-201
6
. The SimGrid Team. All rights reserved. */
+/* Copyright (c) 2007-201
7
. The SimGrid Team. All rights reserved. */
/* This program is free software; you can redistribute it and/or modify it
* under the terms of the license (GNU LGPL) which comes with this package. */
/* This program is free software; you can redistribute it and/or modify it
* under the terms of the license (GNU LGPL) which comes with this package. */
@@
-12,6
+12,7
@@
#include <xbt/base.h>
#include "simgrid/forward.h"
#include <xbt/base.h>
#include "simgrid/forward.h"
+#include <atomic>
#include <simgrid/simix.hpp>
namespace simgrid {
#include <simgrid/simix.hpp>
namespace simgrid {
@@
-30,10
+31,12
@@
namespace activity {
virtual void resume()=0;
virtual void post() =0; // What to do when a simcall terminates
virtual void resume()=0;
virtual void post() =0; // What to do when a simcall terminates
- void ref();
- void unref();
+ // boost::intrusive_ptr<ActivityImpl> support:
+ friend XBT_PUBLIC(void) intrusive_ptr_add_ref(ActivityImpl * activity);
+ friend XBT_PUBLIC(void) intrusive_ptr_release(ActivityImpl * activity);
+
private:
private:
-
int refcount = 1
;
+
std::atomic_int_fast32_t refcount_{0}
;
};
}}} // namespace simgrid::kernel::activity
};
}}} // namespace simgrid::kernel::activity