| /* |
| * Copyright (C) 2008 The Android Open Source Project |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| /* |
| * Functions for interpreting LEB128 (little endian base 128) values |
| */ |
| |
| #include "Leb128.h" |
| |
| /* |
| * Reads an unsigned LEB128 value, updating the given pointer to point |
| * just past the end of the read value and also indicating whether the |
| * value was syntactically valid. The only syntactically *invalid* |
| * values are ones that are five bytes long where the final byte has |
| * any but the low-order four bits set. Additionally, if the limit is |
| * passed as non-NULL and bytes would need to be read past the limit, |
| * then the read is considered invalid. |
| */ |
| int readAndVerifyUnsignedLeb128(const u1** pStream, const u1* limit, |
| bool* okay) { |
| const u1* ptr = *pStream; |
| int result = readUnsignedLeb128(pStream); |
| |
| if (((limit != NULL) && (*pStream > limit)) |
| || (((*pStream - ptr) == 5) && (ptr[4] > 0x0f))) { |
| *okay = false; |
| } |
| |
| return result; |
| } |
| |
| /* |
| * Reads a signed LEB128 value, updating the given pointer to point |
| * just past the end of the read value and also indicating whether the |
| * value was syntactically valid. The only syntactically *invalid* |
| * values are ones that are five bytes long where the final byte has |
| * any but the low-order four bits set. Additionally, if the limit is |
| * passed as non-NULL and bytes would need to be read past the limit, |
| * then the read is considered invalid. |
| */ |
| int readAndVerifySignedLeb128(const u1** pStream, const u1* limit, |
| bool* okay) { |
| const u1* ptr = *pStream; |
| int result = readSignedLeb128(pStream); |
| |
| if (((limit != NULL) && (*pStream > limit)) |
| || (((*pStream - ptr) == 5) && (ptr[4] > 0x0f))) { |
| *okay = false; |
| } |
| |
| return result; |
| } |