| /* |
| * Copyright 2020 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. |
| */ |
| |
| #ifndef ART_LIBARTBASE_BASE_ENDIAN_UTILS_H_ |
| #define ART_LIBARTBASE_BASE_ENDIAN_UTILS_H_ |
| |
| #include <stdint.h> |
| #include <endian.h> |
| #include <vector> |
| |
| namespace art { |
| |
| constexpr uint32_t Get4BE(unsigned char const* pSrc) { |
| return (pSrc[0] << 24) | (pSrc[1] << 16) | (pSrc[2] << 8) | pSrc[3]; |
| } |
| |
| inline void Append1BE(std::vector<uint8_t>& bytes, uint8_t value) { |
| bytes.push_back(value); |
| } |
| |
| inline void Append2BE(std::vector<uint8_t>& bytes, uint16_t value) { |
| bytes.push_back(static_cast<uint8_t>(value >> 8)); |
| bytes.push_back(static_cast<uint8_t>(value)); |
| } |
| |
| inline void Append4BE(std::vector<uint8_t>& bytes, uint32_t value) { |
| bytes.push_back(static_cast<uint8_t>(value >> 24)); |
| bytes.push_back(static_cast<uint8_t>(value >> 16)); |
| bytes.push_back(static_cast<uint8_t>(value >> 8)); |
| bytes.push_back(static_cast<uint8_t>(value)); |
| } |
| |
| inline void Append8BE(std::vector<uint8_t>& bytes, uint64_t value) { |
| bytes.push_back(static_cast<uint8_t>(value >> 56)); |
| bytes.push_back(static_cast<uint8_t>(value >> 48)); |
| bytes.push_back(static_cast<uint8_t>(value >> 40)); |
| bytes.push_back(static_cast<uint8_t>(value >> 32)); |
| bytes.push_back(static_cast<uint8_t>(value >> 24)); |
| bytes.push_back(static_cast<uint8_t>(value >> 16)); |
| bytes.push_back(static_cast<uint8_t>(value >> 8)); |
| bytes.push_back(static_cast<uint8_t>(value)); |
| } |
| |
| inline void AppendUtf16BE(std::vector<uint8_t>& bytes, const uint16_t* chars, |
| size_t char_count) { |
| Append4BE(bytes, char_count); |
| for (size_t i = 0; i < char_count; ++i) { |
| Append2BE(bytes, chars[i]); |
| } |
| } |
| |
| inline void AppendUtf16CompressedBE(std::vector<uint8_t>& bytes, |
| const uint8_t* chars, size_t char_count) { |
| Append4BE(bytes, char_count); |
| for (size_t i = 0; i < char_count; ++i) { |
| Append2BE(bytes, static_cast<uint16_t>(chars[i])); |
| } |
| } |
| |
| // @deprecated |
| inline void Set1(uint8_t* buf, uint8_t val) { |
| *buf = val; |
| } |
| |
| // @deprecated |
| inline void Set2BE(uint8_t* buf, uint16_t val) { |
| *buf++ = (uint8_t)(val >> 8); |
| *buf = (uint8_t)(val); |
| } |
| |
| // @deprecated |
| inline void Set4BE(uint8_t* buf, uint32_t val) { |
| *buf++ = (uint8_t)(val >> 24); |
| *buf++ = (uint8_t)(val >> 16); |
| *buf++ = (uint8_t)(val >> 8); |
| *buf = (uint8_t)(val); |
| } |
| |
| // @deprecated |
| inline void Set8BE(uint8_t* buf, uint64_t val) { |
| *buf++ = (uint8_t)(val >> 56); |
| *buf++ = (uint8_t)(val >> 48); |
| *buf++ = (uint8_t)(val >> 40); |
| *buf++ = (uint8_t)(val >> 32); |
| *buf++ = (uint8_t)(val >> 24); |
| *buf++ = (uint8_t)(val >> 16); |
| *buf++ = (uint8_t)(val >> 8); |
| *buf = (uint8_t)(val); |
| } |
| |
| inline void Write1BE(uint8_t** dst, uint8_t value) { |
| Set1(*dst, value); |
| *dst += sizeof(value); |
| } |
| |
| inline void Write2BE(uint8_t** dst, uint16_t value) { |
| Set2BE(*dst, value); |
| *dst += sizeof(value); |
| } |
| |
| inline void Write4BE(uint8_t** dst, uint32_t value) { |
| Set4BE(*dst, value); |
| *dst += sizeof(value); |
| } |
| |
| inline void Write8BE(uint8_t** dst, uint64_t value) { |
| Set8BE(*dst, value); |
| *dst += sizeof(value); |
| } |
| } // namespace art |
| |
| #endif // ART_LIBARTBASE_BASE_ENDIAN_UTILS_H_ |