13ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdoch// Copyright 2006-2008 the V8 project authors. All rights reserved.
21e0659c275bb392c045087af4f6b0d7565cb3d77Steve Block// Redistribution and use in source and binary forms, with or without
31e0659c275bb392c045087af4f6b0d7565cb3d77Steve Block// modification, are permitted provided that the following conditions are
41e0659c275bb392c045087af4f6b0d7565cb3d77Steve Block// met:
51e0659c275bb392c045087af4f6b0d7565cb3d77Steve Block//
61e0659c275bb392c045087af4f6b0d7565cb3d77Steve Block//     * Redistributions of source code must retain the above copyright
71e0659c275bb392c045087af4f6b0d7565cb3d77Steve Block//       notice, this list of conditions and the following disclaimer.
81e0659c275bb392c045087af4f6b0d7565cb3d77Steve Block//     * Redistributions in binary form must reproduce the above
91e0659c275bb392c045087af4f6b0d7565cb3d77Steve Block//       copyright notice, this list of conditions and the following
101e0659c275bb392c045087af4f6b0d7565cb3d77Steve Block//       disclaimer in the documentation and/or other materials provided
111e0659c275bb392c045087af4f6b0d7565cb3d77Steve Block//       with the distribution.
121e0659c275bb392c045087af4f6b0d7565cb3d77Steve Block//     * Neither the name of Google Inc. nor the names of its
131e0659c275bb392c045087af4f6b0d7565cb3d77Steve Block//       contributors may be used to endorse or promote products derived
141e0659c275bb392c045087af4f6b0d7565cb3d77Steve Block//       from this software without specific prior written permission.
151e0659c275bb392c045087af4f6b0d7565cb3d77Steve Block//
161e0659c275bb392c045087af4f6b0d7565cb3d77Steve Block// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
171e0659c275bb392c045087af4f6b0d7565cb3d77Steve Block// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
181e0659c275bb392c045087af4f6b0d7565cb3d77Steve Block// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
191e0659c275bb392c045087af4f6b0d7565cb3d77Steve Block// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
201e0659c275bb392c045087af4f6b0d7565cb3d77Steve Block// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
211e0659c275bb392c045087af4f6b0d7565cb3d77Steve Block// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
221e0659c275bb392c045087af4f6b0d7565cb3d77Steve Block// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
231e0659c275bb392c045087af4f6b0d7565cb3d77Steve Block// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
241e0659c275bb392c045087af4f6b0d7565cb3d77Steve Block// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
251e0659c275bb392c045087af4f6b0d7565cb3d77Steve Block// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
261e0659c275bb392c045087af4f6b0d7565cb3d77Steve Block// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
271e0659c275bb392c045087af4f6b0d7565cb3d77Steve Block
283ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdoch#ifndef V8_COMPILER_INTRINSICS_H_
293ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdoch#define V8_COMPILER_INTRINSICS_H_
30592a9fc1d8ea420377a2e7efd0600e20b058be2bBen Murdoch
3185b71799222b55eb5dd74ea26efe0c64ab655c8cBen Murdochnamespace v8 {
3285b71799222b55eb5dd74ea26efe0c64ab655c8cBen Murdochnamespace internal {
33592a9fc1d8ea420377a2e7efd0600e20b058be2bBen Murdoch
343ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdochclass CompilerIntrinsics {
3585b71799222b55eb5dd74ea26efe0c64ab655c8cBen Murdoch public:
363ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdoch  // Returns number of zero bits preceding least significant 1 bit.
373ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdoch  // Undefined for zero value.
383ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdoch  INLINE(static int CountTrailingZeros(uint32_t value));
393ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdoch
403ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdoch  // Returns number of zero bits following most significant 1 bit.
413ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdoch  // Undefined for zero value.
423ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdoch  INLINE(static int CountLeadingZeros(uint32_t value));
433ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdoch};
44592a9fc1d8ea420377a2e7efd0600e20b058be2bBen Murdoch
453ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdoch#ifdef __GNUC__
463ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdochint CompilerIntrinsics::CountTrailingZeros(uint32_t value) {
473ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdoch  return __builtin_ctz(value);
483ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdoch}
493ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdoch
503ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdochint CompilerIntrinsics::CountLeadingZeros(uint32_t value) {
513ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdoch  return __builtin_clz(value);
523ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdoch}
53592a9fc1d8ea420377a2e7efd0600e20b058be2bBen Murdoch
543ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdoch#elif defined(_MSC_VER)
5585b71799222b55eb5dd74ea26efe0c64ab655c8cBen Murdoch
563ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdoch#pragma intrinsic(_BitScanForward)
573ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdoch#pragma intrinsic(_BitScanReverse)
5885b71799222b55eb5dd74ea26efe0c64ab655c8cBen Murdoch
593ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdochint CompilerIntrinsics::CountTrailingZeros(uint32_t value) {
603ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdoch  unsigned long result;  //NOLINT
613ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdoch  _BitScanForward(&result, static_cast<long>(value));  //NOLINT
623ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdoch  return static_cast<int>(result);
633ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdoch}
6485b71799222b55eb5dd74ea26efe0c64ab655c8cBen Murdoch
653ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdochint CompilerIntrinsics::CountLeadingZeros(uint32_t value) {
663ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdoch  unsigned long result;  //NOLINT
673ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdoch  _BitScanReverse(&result, static_cast<long>(value));  //NOLINT
683ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdoch  return 31 - static_cast<int>(result);
693ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdoch}
7085b71799222b55eb5dd74ea26efe0c64ab655c8cBen Murdoch
713ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdoch#else
723ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdoch#error Unsupported compiler
733ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdoch#endif
7485b71799222b55eb5dd74ea26efe0c64ab655c8cBen Murdoch
7585b71799222b55eb5dd74ea26efe0c64ab655c8cBen Murdoch} }  // namespace v8::internal
7685b71799222b55eb5dd74ea26efe0c64ab655c8cBen Murdoch
773ef787dbeca8a5fb1086949cda830dccee07bfbdBen Murdoch#endif  // V8_COMPILER_INTRINSICS_H_
78