Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(54)

Side by Side Diff: courgette/rel32_finder.h

Issue 2008253004: Refactor rel32 searching process for x64 to make it more similar to x86. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Rollback to original courgette algorithm and improve unittests Created 4 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2016 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef COURGETTE_REL32_FINDER_WIN32_X86_H_ 5 #ifndef COURGETTE_REL32_FINDER_H_
6 #define COURGETTE_REL32_FINDER_WIN32_X86_H_ 6 #define COURGETTE_REL32_FINDER_H_
7 7
8 #include <stdint.h> 8 #include <stdint.h>
9 9
10 #include <map> 10 #include <map>
11 #include <vector> 11 #include <vector>
12 12
13 #include "courgette/image_utils.h" 13 #include "courgette/image_utils.h"
14 14
15 namespace courgette { 15 namespace courgette {
16 16
17 // A helper class to scan through a section of code to extract RVAs. 17 // A helper class to scan through a section of code to extract RVAs.
18 class Rel32FinderWin32X86 { 18 class Rel32Finder {
19 public: 19 public:
20 Rel32FinderWin32X86(RVA relocs_start_rva, RVA relocs_end_rva); 20 Rel32Finder() = default;
huangs 2016/05/26 22:40:55 If the default constructor is unused (perhaps by s
etiennep 2016/05/27 18:12:34 Done.
21 virtual ~Rel32FinderWin32X86(); 21 Rel32Finder(RVA relocs_start_rva, RVA relocs_end_rva);
22 virtual ~Rel32Finder() = default;
22 23
23 // Swaps data in |rel32_locations_| with |dest|. 24 // Swaps data in |rel32_locations_| with |dest|.
24 void SwapRel32Locations(std::vector<RVA>* dest); 25 void SwapRel32Locations(std::vector<RVA>* dest);
25 26
26 #if COURGETTE_HISTOGRAM_TARGETS 27 #if COURGETTE_HISTOGRAM_TARGETS
27 // Swaps data in |rel32_target_rvas_| with |dest|. 28 // Swaps data in |rel32_target_rvas_| with |dest|.
28 void SwapRel32TargetRVAs(std::map<RVA, int>* dest); 29 void SwapRel32TargetRVAs(std::map<RVA, int>* dest);
29 #endif 30 #endif
30 31
31 // Scans through [|start_pointer|, |end_pointer|) for rel32 addresses. Seeks 32 // Scans through [|start_pointer|, |end_pointer|) for rel32 addresses. Seeks
32 // RVAs that satisfy the following: 33 // RVAs that satisfy the following:
33 // - Do not overlap with |abs32_locations| (assumed sorted). 34 // - Do not overlap with |abs32_locations| (assumed sorted).
34 // - Do not overlap with [relocs_start_rva, relocs_end_rva). 35 // - Do not overlap with [relocs_start_rva, relocs_end_rva).
35 // - Whose targets are in [|start_rva|, |end_rva|). 36 // - Whose targets are in [|start_rva|, |end_rva|).
huangs 2016/05/26 22:11:17 Update comment re. role of |size_of_image|?
etiennep 2016/05/27 18:12:33 Done.
36 // The sorted results are written to |rel32_locations_|. 37 // The sorted results are written to |rel32_locations_|.
37 virtual void Find(const uint8_t* start_pointer, 38 virtual void Find(const uint8_t* start_pointer,
38 const uint8_t* end_pointer, 39 const uint8_t* end_pointer,
39 RVA start_rva, 40 RVA start_rva,
40 RVA end_rva, 41 RVA end_rva,
42 uint32_t size_of_image_,
huangs 2016/05/26 22:11:17 |size_of_image|. Trailing underscore is for priva
etiennep 2016/05/27 18:12:34 Done.
41 const std::vector<RVA>& abs32_locations) = 0; 43 const std::vector<RVA>& abs32_locations) = 0;
42 44
43 protected: 45 protected:
44 const RVA relocs_start_rva_; 46 const RVA relocs_start_rva_ = 0;
huangs 2016/05/26 22:40:55 Remove " = 0" if we remove default constructor.
etiennep 2016/05/27 18:12:33 Done.
45 const RVA relocs_end_rva_; 47 const RVA relocs_end_rva_ = 0;
46 48
47 std::vector<RVA> rel32_locations_; 49 std::vector<RVA> rel32_locations_;
48 50
49 #if COURGETTE_HISTOGRAM_TARGETS 51 #if COURGETTE_HISTOGRAM_TARGETS
50 std::map<RVA, int> rel32_target_rvas_; 52 std::map<RVA, int> rel32_target_rvas_;
51 #endif 53 #endif
52 }; 54 };
53 55
54 // The basic implementation performs naive scan for rel32 JMP and Jcc opcodes
55 // (excluding JPO/JPE) disregarding instruction alignment.
56 class Rel32FinderWin32X86_Basic : public Rel32FinderWin32X86 {
57 public:
58 Rel32FinderWin32X86_Basic(RVA relocs_start_rva, RVA relocs_end_rva);
59 virtual ~Rel32FinderWin32X86_Basic();
60
61 // Rel32FinderWin32X86 implementation.
62 void Find(const uint8_t* start_pointer,
63 const uint8_t* end_pointer,
64 RVA start_rva,
65 RVA end_rva,
66 const std::vector<RVA>& abs32_locations) override;
67 };
68
69 } // namespace courgette 56 } // namespace courgette
70 57
71 #endif // COURGETTE_REL32_FINDER_WIN32_X86_H_ 58 #endif // COURGETTE_REL32_FINDER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698