blob: 8de6d1eeb12e603d77ab1fa56f29e944f5179d44 [file] [log] [blame]
Ben Murdoch3fb3ca82011-12-02 17:19:32 +00001// Copyright 2011 the V8 project authors. All rights reserved.
Ben Murdochb8a8cc12014-11-26 15:28:44 +00002// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
Steve Blocka7e24c12009-10-30 11:49:00 +00004
5// CPU specific code for ia32 independent of OS goes here.
6
7#ifdef __GNUC__
Ben Murdochb8a8cc12014-11-26 15:28:44 +00008#include "src/third_party/valgrind/valgrind.h"
Steve Blocka7e24c12009-10-30 11:49:00 +00009#endif
10
Ben Murdochb8a8cc12014-11-26 15:28:44 +000011#if V8_TARGET_ARCH_IA32
Leon Clarkef7060e22010-06-03 12:02:55 +010012
Ben Murdochb8a8cc12014-11-26 15:28:44 +000013#include "src/assembler.h"
14#include "src/macro-assembler.h"
Steve Blocka7e24c12009-10-30 11:49:00 +000015
16namespace v8 {
17namespace internal {
18
Ben Murdochb8a8cc12014-11-26 15:28:44 +000019void CpuFeatures::FlushICache(void* start, size_t size) {
Steve Blocka7e24c12009-10-30 11:49:00 +000020 // No need to flush the instruction cache on Intel. On Intel instruction
21 // cache flushing is only necessary when multiple cores running the same
22 // code simultaneously. V8 (and JavaScript) is single threaded and when code
23 // is patched on an intel CPU the core performing the patching will have its
24 // own instruction cache updated automatically.
25
26 // If flushing of the instruction cache becomes necessary Windows has the
27 // API function FlushInstructionCache.
28
29 // By default, valgrind only checks the stack for writes that might need to
30 // invalidate already cached translated code. This leads to random
31 // instability when code patches or moves are sometimes unnoticed. One
32 // solution is to run valgrind with --smc-check=all, but this comes at a big
33 // performance cost. We can notify valgrind to invalidate its cache.
34#ifdef VALGRIND_DISCARD_TRANSLATIONS
Ben Murdoch3fb3ca82011-12-02 17:19:32 +000035 unsigned res = VALGRIND_DISCARD_TRANSLATIONS(start, size);
36 USE(res);
Steve Blocka7e24c12009-10-30 11:49:00 +000037#endif
38}
39
Ben Murdoch4a90d5f2016-03-22 12:00:34 +000040} // namespace internal
41} // namespace v8
Leon Clarkef7060e22010-06-03 12:02:55 +010042
43#endif // V8_TARGET_ARCH_IA32