15460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao//===- LEB128.cpp ---------------------------------------------------------===//
25460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao//
35460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao//                     The MCLinker Project
45460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao//
55460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao// This file is distributed under the University of Illinois Open Source
65460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao// License. See LICENSE.TXT for details.
75460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao//
85460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao//===----------------------------------------------------------------------===//
937b74a387bb3993387029859c2d9d051c41c724eStephen Hines#include "mcld/Support/LEB128.h"
105460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao
115460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liaonamespace mcld {
125460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao
135460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liaonamespace leb128 {
145460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao
155460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao//===---------------------- LEB128 Encoding APIs -------------------------===//
1637b74a387bb3993387029859c2d9d051c41c724eStephen Hinestemplate <>
1737b74a387bb3993387029859c2d9d051c41c724eStephen Hinessize_t encode<uint64_t>(ByteType*& pBuf, uint64_t pValue) {
185460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  size_t size = 0;
195460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  do {
205460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    ByteType byte = pValue & 0x7f;
215460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    pValue >>= 7;
225460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    if (pValue)
235460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao      byte |= 0x80;
245460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    *pBuf++ = byte;
255460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    size++;
265460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  } while (pValue);
275460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao
285460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  return size;
295460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao}
305460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao
315460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao/*
325460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao * Fast version for encoding 32-bit integer. This unrolls the loop in the
335460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao * generic version defined above.
345460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao */
3537b74a387bb3993387029859c2d9d051c41c724eStephen Hinestemplate <>
3637b74a387bb3993387029859c2d9d051c41c724eStephen Hinessize_t encode<uint32_t>(ByteType*& pBuf, uint32_t pValue) {
375460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  if ((pValue & ~0x7f) == 0) {
385460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    *pBuf++ = static_cast<ByteType>(pValue);
395460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    return 1;
4037b74a387bb3993387029859c2d9d051c41c724eStephen Hines  } else if ((pValue & ~0x3fff) == 0) {
4137b74a387bb3993387029859c2d9d051c41c724eStephen Hines    *pBuf++ = static_cast<ByteType>((pValue & 0x7f) | 0x80);
4237b74a387bb3993387029859c2d9d051c41c724eStephen Hines    *pBuf++ = static_cast<ByteType>((pValue >> 7) & 0x7f);
435460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    return 2;
445460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  } else if ((pValue & ~0x1fffff) == 0) {
4537b74a387bb3993387029859c2d9d051c41c724eStephen Hines    *pBuf++ = static_cast<ByteType>((pValue & 0x7f) | 0x80);
4637b74a387bb3993387029859c2d9d051c41c724eStephen Hines    *pBuf++ = static_cast<ByteType>(((pValue >> 7) & 0x7f) | 0x80);
4737b74a387bb3993387029859c2d9d051c41c724eStephen Hines    *pBuf++ = static_cast<ByteType>((pValue >> 14) & 0x7f);
485460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    return 3;
495460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  } else if ((pValue & ~0xfffffff) == 0) {
5037b74a387bb3993387029859c2d9d051c41c724eStephen Hines    *pBuf++ = static_cast<ByteType>((pValue & 0x7f) | 0x80);
5137b74a387bb3993387029859c2d9d051c41c724eStephen Hines    *pBuf++ = static_cast<ByteType>(((pValue >> 7) & 0x7f) | 0x80);
525460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    *pBuf++ = static_cast<ByteType>(((pValue >> 14) & 0x7f) | 0x80);
5337b74a387bb3993387029859c2d9d051c41c724eStephen Hines    *pBuf++ = static_cast<ByteType>((pValue >> 21) & 0x7f);
545460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    return 4;
555460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  } else {
5637b74a387bb3993387029859c2d9d051c41c724eStephen Hines    *pBuf++ = static_cast<ByteType>((pValue & 0x7f) | 0x80);
5737b74a387bb3993387029859c2d9d051c41c724eStephen Hines    *pBuf++ = static_cast<ByteType>(((pValue >> 7) & 0x7f) | 0x80);
585460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    *pBuf++ = static_cast<ByteType>(((pValue >> 14) & 0x7f) | 0x80);
595460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    *pBuf++ = static_cast<ByteType>(((pValue >> 21) & 0x7f) | 0x80);
6037b74a387bb3993387029859c2d9d051c41c724eStephen Hines    *pBuf++ = static_cast<ByteType>((pValue >> 28) & 0x7f);
615460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    return 5;
625460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  }
635460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  // unreachable
645460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao}
655460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao
6637b74a387bb3993387029859c2d9d051c41c724eStephen Hinestemplate <>
6737b74a387bb3993387029859c2d9d051c41c724eStephen Hinessize_t encode<int64_t>(ByteType*& pBuf, int64_t pValue) {
685460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  size_t size = 0;
695460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  bool more = true;
705460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao
715460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  do {
725460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    ByteType byte = pValue & 0x7f;
735460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    pValue >>= 7;
745460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao
7537b74a387bb3993387029859c2d9d051c41c724eStephen Hines    if (((pValue == 0) && ((byte & 0x40) == 0)) ||
765460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao        ((pValue == -1) && ((byte & 0x40) == 0x40)))
775460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao      more = false;
785460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    else
795460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao      byte |= 0x80;
805460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao
815460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    *pBuf++ = byte;
825460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    size++;
835460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  } while (more);
845460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao
855460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  return size;
865460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao}
875460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao
8837b74a387bb3993387029859c2d9d051c41c724eStephen Hinestemplate <>
8937b74a387bb3993387029859c2d9d051c41c724eStephen Hinessize_t encode<int32_t>(ByteType*& pBuf, int32_t pValue) {
905460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  return encode<int64_t>(pBuf, static_cast<int64_t>(pValue));
915460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao}
925460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao
935460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao//===---------------------- LEB128 Decoding APIs -------------------------===//
945460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao
9537b74a387bb3993387029859c2d9d051c41c724eStephen Hinestemplate <>
9637b74a387bb3993387029859c2d9d051c41c724eStephen Hinesuint64_t decode<uint64_t>(const ByteType* pBuf, size_t& pSize) {
975460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  uint64_t result = 0;
985460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao
995460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  if ((*pBuf & 0x80) == 0) {
1005460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    pSize = 1;
1015460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    return *pBuf;
1025460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  } else if ((*(pBuf + 1) & 0x80) == 0) {
1035460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    pSize = 2;
10437b74a387bb3993387029859c2d9d051c41c724eStephen Hines    return ((*(pBuf + 1) & 0x7f) << 7) | (*pBuf & 0x7f);
1055460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  } else if ((*(pBuf + 2) & 0x80) == 0) {
1065460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    pSize = 3;
10737b74a387bb3993387029859c2d9d051c41c724eStephen Hines    return ((*(pBuf + 2) & 0x7f) << 14) | ((*(pBuf + 1) & 0x7f) << 7) |
1085460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao           (*pBuf & 0x7f);
1095460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  } else {
1105460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    pSize = 4;
11137b74a387bb3993387029859c2d9d051c41c724eStephen Hines    result = ((*(pBuf + 3) & 0x7f) << 21) | ((*(pBuf + 2) & 0x7f) << 14) |
11237b74a387bb3993387029859c2d9d051c41c724eStephen Hines             ((*(pBuf + 1) & 0x7f) << 7) | (*pBuf & 0x7f);
1135460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  }
1145460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao
1155460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  if ((*(pBuf + 3) & 0x80) != 0) {
1165460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    // Large number which is an unusual case.
1175460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    unsigned shift;
1185460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    ByteType byte;
1195460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao
1205460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    // Start the read from the 4th byte.
1215460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    shift = 28;
1225460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    pBuf += 4;
1235460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    do {
1245460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao      byte = *pBuf;
1255460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao      pBuf++;
1265460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao      pSize++;
1275460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao      result |= (static_cast<uint64_t>(byte & 0x7f) << shift);
1285460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao      shift += 7;
1295460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    } while (byte & 0x80);
1305460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  }
1315460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao
1325460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  return result;
1335460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao}
1345460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao
13537b74a387bb3993387029859c2d9d051c41c724eStephen Hinestemplate <>
13637b74a387bb3993387029859c2d9d051c41c724eStephen Hinesuint64_t decode<uint64_t>(const ByteType*& pBuf) {
1375460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  ByteType byte;
1385460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  uint64_t result;
1395460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao
1405460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  byte = *pBuf++;
1415460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  result = byte & 0x7f;
1425460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  if ((byte & 0x80) == 0) {
1435460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    return result;
1445460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  } else {
1455460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    byte = *pBuf++;
14637b74a387bb3993387029859c2d9d051c41c724eStephen Hines    result |= ((byte & 0x7f) << 7);
1475460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    if ((byte & 0x80) == 0) {
1485460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao      return result;
1495460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    } else {
1505460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao      byte = *pBuf++;
1515460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao      result |= (byte & 0x7f) << 14;
1525460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao      if ((byte & 0x80) == 0) {
1535460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao        return result;
1545460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao      } else {
1555460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao        byte = *pBuf++;
1565460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao        result |= (byte & 0x7f) << 21;
1575460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao        if ((byte & 0x80) == 0) {
1585460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao          return result;
1595460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao        }
1605460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao      }
1615460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    }
1625460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  }
1635460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao
1645460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  // Large number which is an unusual case.
1655460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  unsigned shift;
1665460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao
1675460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  // Start the read from the 4th byte.
1685460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  shift = 28;
1695460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  do {
1705460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    byte = *pBuf++;
1715460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    result |= (static_cast<uint64_t>(byte & 0x7f) << shift);
1725460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    shift += 7;
1735460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  } while (byte & 0x80);
1745460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao
1755460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  return result;
1765460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao}
1775460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao
1785460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao/*
1795460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao * Signed LEB128 decoding is Similar to the unsigned version but setup the sign
1805460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao * bit if necessary. This is rarely used, therefore we don't provide unrolling
1815460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao * version like decode() to save the code size.
1825460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao */
18337b74a387bb3993387029859c2d9d051c41c724eStephen Hinestemplate <>
18437b74a387bb3993387029859c2d9d051c41c724eStephen Hinesint64_t decode<int64_t>(const ByteType* pBuf, size_t& pSize) {
1855460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  uint64_t result = 0;
1865460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  ByteType byte;
1875460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  unsigned shift = 0;
1885460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao
1895460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  pSize = 0;
1905460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  do {
1915460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    byte = *pBuf;
1925460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    pBuf++;
1935460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    pSize++;
1945460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    result |= (static_cast<uint64_t>(byte & 0x7f) << shift);
1955460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    shift += 7;
1965460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  } while (byte & 0x80);
1975460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao
1985460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  if ((shift < (8 * sizeof(result))) && (byte & 0x40))
1995460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    result |= ((static_cast<uint64_t>(-1)) << shift);
2005460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao
2015460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  return result;
2025460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao}
2035460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao
20437b74a387bb3993387029859c2d9d051c41c724eStephen Hinestemplate <>
20537b74a387bb3993387029859c2d9d051c41c724eStephen Hinesint64_t decode<int64_t>(const ByteType*& pBuf) {
2065460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  uint64_t result = 0;
2075460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  ByteType byte;
2085460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  unsigned shift = 0;
2095460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao
2105460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  do {
2115460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    byte = *pBuf;
2125460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    pBuf++;
2135460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    result |= (static_cast<uint64_t>(byte & 0x7f) << shift);
2145460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    shift += 7;
2155460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  } while (byte & 0x80);
2165460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao
2175460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  if ((shift < (8 * sizeof(result))) && (byte & 0x40))
2185460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao    result |= ((static_cast<uint64_t>(-1)) << shift);
2195460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao
2205460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao  return result;
2215460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao}
2225460a1f25d9ddecb5c70667267d66d51af177a99Shih-wei Liao
22337b74a387bb3993387029859c2d9d051c41c724eStephen Hines}  // namespace leb128
22437b74a387bb3993387029859c2d9d051c41c724eStephen Hines}  // namespace mcld
225