Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(242)

Side by Side Diff: runtime/vm/simulator_arm64.h

Issue 1562253002: Add a CompareAndSwapUint32 variant to AtomicOperations so that it is possible to a CAS of a 32 bit … (Closed) Base URL: git@github.com:dart-lang/sdk.git@master
Patch Set: Created 4 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « runtime/vm/simulator_arm.cc ('k') | runtime/vm/simulator_arm64.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file
2 // for details. All rights reserved. Use of this source code is governed by a 2 // for details. All rights reserved. Use of this source code is governed by a
3 // BSD-style license that can be found in the LICENSE file. 3 // BSD-style license that can be found in the LICENSE file.
4 4
5 // Declares a Simulator for ARM64 instructions if we are not generating a native 5 // Declares a Simulator for ARM64 instructions if we are not generating a native
6 // ARM64 binary. This Simulator allows us to run and debug ARM64 code generation 6 // ARM64 binary. This Simulator allows us to run and debug ARM64 code generation
7 // on regular desktop machines. 7 // on regular desktop machines.
8 // Dart calls into generated code by "calling" the InvokeDartCode stub, 8 // Dart calls into generated code by "calling" the InvokeDartCode stub,
9 // which will start execution in the Simulator or forwards to the real entry 9 // which will start execution in the Simulator or forwards to the real entry
10 // on a ARM64 HW platform. 10 // on a ARM64 HW platform.
(...skipping 84 matching lines...) Expand 10 before | Expand all | Expand 10 after
95 int64_t parameter2, 95 int64_t parameter2,
96 int64_t parameter3, 96 int64_t parameter3,
97 bool fp_return = false, 97 bool fp_return = false,
98 bool fp_args = false); 98 bool fp_args = false);
99 99
100 // Implementation of atomic compare and exchange in the same synchronization 100 // Implementation of atomic compare and exchange in the same synchronization
101 // domain as other synchronization primitive instructions (e.g. ldrex, strex). 101 // domain as other synchronization primitive instructions (e.g. ldrex, strex).
102 static uword CompareExchange(uword* address, 102 static uword CompareExchange(uword* address,
103 uword compare_value, 103 uword compare_value,
104 uword new_value); 104 uword new_value);
105 static uint32_t CompareExchangeUint32(uint32_t* address,
106 uint32_t compare_value,
107 uint32_t new_value);
105 108
106 // Runtime and native call support. 109 // Runtime and native call support.
107 enum CallKind { 110 enum CallKind {
108 kRuntimeCall, 111 kRuntimeCall,
109 kLeafRuntimeCall, 112 kLeafRuntimeCall,
110 kLeafFloatRuntimeCall, 113 kLeafFloatRuntimeCall,
111 kBootstrapNativeCall, 114 kBootstrapNativeCall,
112 kNativeCall 115 kNativeCall
113 }; 116 };
114 static uword RedirectExternalReference(uword function, 117 static uword RedirectExternalReference(uword function,
(...skipping 154 matching lines...) Expand 10 before | Expand all | Expand 10 after
269 } 272 }
270 273
271 friend class SimulatorDebugger; 274 friend class SimulatorDebugger;
272 friend class SimulatorSetjmpBuffer; 275 friend class SimulatorSetjmpBuffer;
273 DISALLOW_COPY_AND_ASSIGN(Simulator); 276 DISALLOW_COPY_AND_ASSIGN(Simulator);
274 }; 277 };
275 278
276 } // namespace dart 279 } // namespace dart
277 280
278 #endif // VM_SIMULATOR_ARM64_H_ 281 #endif // VM_SIMULATOR_ARM64_H_
OLDNEW
« no previous file with comments | « runtime/vm/simulator_arm.cc ('k') | runtime/vm/simulator_arm64.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698