Commit 05a04b10 authored by erik.corry@gmail.com's avatar erik.corry@gmail.com

Fix endianism issues in regexp interpreter.

Review URL: http://codereview.chromium.org/18613

git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@1115 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent bfbda9c8
...@@ -43,7 +43,7 @@ void RegExpMacroAssemblerIrregexp::Emit(uint32_t byte, ...@@ -43,7 +43,7 @@ void RegExpMacroAssemblerIrregexp::Emit(uint32_t byte,
if (pc_ + 3 >= buffer_.length()) { if (pc_ + 3 >= buffer_.length()) {
Expand(); Expand();
} }
Store32(buffer_.start() + pc_, word); *reinterpret_cast<uint32_t*>(buffer_.start() + pc_) = word;
pc_ += 4; pc_ += 4;
} }
...@@ -53,7 +53,7 @@ void RegExpMacroAssemblerIrregexp::Emit16(uint32_t word) { ...@@ -53,7 +53,7 @@ void RegExpMacroAssemblerIrregexp::Emit16(uint32_t word) {
if (pc_ + 1 >= buffer_.length()) { if (pc_ + 1 >= buffer_.length()) {
Expand(); Expand();
} }
Store16(buffer_.start() + pc_, word); *reinterpret_cast<uint16_t*>(buffer_.start() + pc_) = word;
pc_ += 2; pc_ += 2;
} }
...@@ -63,7 +63,7 @@ void RegExpMacroAssemblerIrregexp::Emit32(uint32_t word) { ...@@ -63,7 +63,7 @@ void RegExpMacroAssemblerIrregexp::Emit32(uint32_t word) {
if (pc_ + 3 >= buffer_.length()) { if (pc_ + 3 >= buffer_.length()) {
Expand(); Expand();
} }
Store32(buffer_.start() + pc_, word); *reinterpret_cast<uint32_t*>(buffer_.start() + pc_) = word;
pc_ += 4; pc_ += 4;
} }
......
...@@ -60,8 +60,8 @@ void RegExpMacroAssemblerIrregexp::Bind(Label* l) { ...@@ -60,8 +60,8 @@ void RegExpMacroAssemblerIrregexp::Bind(Label* l) {
int pos = l->pos(); int pos = l->pos();
while (pos != 0) { while (pos != 0) {
int fixup = pos; int fixup = pos;
pos = Load32(buffer_.start() + fixup); pos = *reinterpret_cast<int32_t*>(buffer_.start() + fixup);
Store32(buffer_.start() + fixup, pc_); *reinterpret_cast<uint32_t*>(buffer_.start() + fixup) = pc_;
} }
} }
l->bind_to(pc_); l->bind_to(pc_);
......
...@@ -527,55 +527,6 @@ static inline void CopyChars(sinkchar* dest, const sourcechar* src, int chars) { ...@@ -527,55 +527,6 @@ static inline void CopyChars(sinkchar* dest, const sourcechar* src, int chars) {
} }
static inline int Load16(const byte* ptr) {
#ifdef CAN_READ_UNALIGNED
return *reinterpret_cast<const uint16_t*>(ptr);
#else
uint32_t word;
word = ptr[1];
word |= ptr[0] << 8;
return word;
#endif
}
static inline int Load32(const byte* ptr) {
#ifdef CAN_READ_UNALIGNED
return *reinterpret_cast<const uint32_t*>(ptr);
#else
uint32_t word;
word = ptr[3];
word |= ptr[2] << 8;
word |= ptr[1] << 16;
word |= ptr[0] << 24;
return word;
#endif
}
static inline void Store16(byte* ptr, uint16_t value) {
#ifdef CAN_READ_UNALIGNED
*reinterpret_cast<uint16_t*>(ptr) = value;
#else
// Cast to avoid warning C4244 when compiling with Microsoft Visual C++.
ptr[1] = static_cast<byte>(value);
ptr[0] = value >> 8;
#endif
}
static inline void Store32(byte* ptr, uint32_t value) {
#ifdef CAN_READ_UNALIGNED
*reinterpret_cast<uint32_t*>(ptr) = value;
#else
ptr[3] = value;
ptr[2] = value >> 8;
ptr[1] = value >> 16;
ptr[0] = value >> 24;
#endif
}
} } // namespace v8::internal } } // namespace v8::internal
#endif // V8_UTILS_H_ #endif // V8_UTILS_H_
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment