| /* |
| * Copyright (C) 2017 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_LIBDEXFILE_DEX_DEX_FILE_TRACKING_REGISTRAR_H_ |
| #define ART_LIBDEXFILE_DEX_DEX_FILE_TRACKING_REGISTRAR_H_ |
| |
| #include <deque> |
| #include <tuple> |
| |
| #include "dex_file.h" |
| |
| namespace art { |
| namespace dex { |
| namespace tracking { |
| |
| // Class for (un)poisoning various sections of Dex Files |
| // |
| // This class provides the means to log accesses only of sections whose |
| // accesses are needed. All accesses are displayed as stack traces in |
| // logcat. |
| class DexFileTrackingRegistrar { |
| public: |
| explicit DexFileTrackingRegistrar(const DexFile* const dex_file) |
| : dex_file_(dex_file) { |
| } |
| |
| // This function is where the functions below it are called to actually |
| // poison sections. |
| void SetDexSections(); |
| |
| // Uses data contained inside range_values_ to poison memory through the |
| // memory tool. |
| void SetCurrentRanges(); |
| |
| private: |
| void SetDexFileRegistration(bool should_poison); |
| |
| // Set of functions concerning Code Items of dex_file_ |
| void SetAllCodeItemRegistration(bool should_poison); |
| // Sets the insns_ section of all code items. |
| void SetAllInsnsRegistration(bool should_poison); |
| // This function finds the code item of a class based on class name. |
| void SetCodeItemRegistration(const char* class_name, bool should_poison); |
| // Sets the size and offset information along with first instruction in insns_ |
| // section of all code items. |
| void SetAllCodeItemStartRegistration(bool should_poison); |
| |
| // Set of functions concerning String Data Items of dex_file_ |
| void SetAllStringDataRegistration(bool should_poison); |
| // Sets the first byte of size value and data section of all string data |
| // items. |
| void SetAllStringDataStartRegistration(bool should_poison); |
| |
| // Contains tuples of all ranges of memory that need to be explicitly |
| // (un)poisoned by the memory tool. |
| std::deque<std::tuple<const void *, size_t, bool>> range_values_; |
| |
| const DexFile* const dex_file_; |
| }; |
| |
| // This function is meant to called externally to use DexfileTrackingRegistrar |
| void RegisterDexFile(const DexFile* dex_file); |
| |
| } // namespace tracking |
| } // namespace dex |
| } // namespace art |
| |
| #endif // ART_LIBDEXFILE_DEX_DEX_FILE_TRACKING_REGISTRAR_H_ |