2 * Copyright (C) 2011 Apple Inc. All rights reserved.
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions
7 * 1. Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer.
9 * 2. Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution.
13 * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS''
14 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
15 * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS
17 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
18 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
19 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
20 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
21 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
22 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
23 * THE POSSIBILITY OF SUCH DAMAGE.
26 #ifndef JITWriteBarrier_h
27 #define JITWriteBarrier_h
31 #include "MacroAssembler.h"
32 #include "SlotVisitor.h"
33 #include "UnusedPointer.h"
34 #include "WriteBarrier.h"
41 // Needs to be even to appease some of the backends.
42 #define JITWriteBarrierFlag ((void*)2)
43 class JITWriteBarrierBase
{
45 typedef void* (JITWriteBarrierBase::*UnspecifiedBoolType
);
46 operator UnspecifiedBoolType
*() const { return get() ? reinterpret_cast<UnspecifiedBoolType
*>(1) : 0; }
47 bool operator!() const { return !get(); }
49 void setFlagOnBarrier()
52 m_location
= CodeLocationDataLabelPtr(JITWriteBarrierFlag
);
55 bool isFlagged() const
60 void setLocation(CodeLocationDataLabelPtr location
)
63 m_location
= location
;
66 CodeLocationDataLabelPtr
location() const
68 ASSERT((!!m_location
) && m_location
.executableAddress() != JITWriteBarrierFlag
);
72 void clear() { clear(0); }
73 void clearToUnusedPointer() { clear(reinterpret_cast<void*>(unusedPointer
)); }
80 void set(VM
&, CodeLocationDataLabelPtr location
, JSCell
* owner
, JSCell
* value
)
82 Heap::writeBarrier(owner
, value
);
83 m_location
= location
;
84 ASSERT(((!!m_location
) && m_location
.executableAddress() != JITWriteBarrierFlag
) || (location
.executableAddress() == m_location
.executableAddress()));
85 MacroAssembler::repatchPointer(m_location
, value
);
86 ASSERT(get() == value
);
91 if (!m_location
|| m_location
.executableAddress() == JITWriteBarrierFlag
)
93 void* result
= static_cast<JSCell
*>(MacroAssembler::readPointer(m_location
));
94 if (result
== reinterpret_cast<void*>(unusedPointer
))
96 return static_cast<JSCell
*>(result
);
100 void clear(void* clearedValue
)
104 if (m_location
.executableAddress() != JITWriteBarrierFlag
)
105 MacroAssembler::repatchPointer(m_location
, clearedValue
);
108 CodeLocationDataLabelPtr m_location
;
111 #undef JITWriteBarrierFlag
113 template <typename T
> class JITWriteBarrier
: public JITWriteBarrierBase
{
119 void set(VM
& vm
, CodeLocationDataLabelPtr location
, JSCell
* owner
, T
* value
)
123 JITWriteBarrierBase::set(vm
, location
, owner
, value
);
125 void set(VM
& vm
, JSCell
* owner
, T
* value
)
127 set(vm
, location(), owner
, value
);
131 T
* result
= static_cast<T
*>(JITWriteBarrierBase::get());
133 validateCell(result
);
138 template<typename T
> inline void SlotVisitor::append(JITWriteBarrier
<T
>* slot
)
140 internalAppend(slot
->get());
145 #endif // ENABLE(JIT)