blob: e243986f52716f1c8fc37aa31048fe94f647a3bd [file] [log] [blame]
[email protected]43a9e242011-04-06 17:42:451// Copyright (c) 2011 The Chromium Authors. All rights reserved.
[email protected]f76b3b02009-05-06 04:02:102// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#ifndef COURGETTE_ENCODED_PROGRAM_H_
6#define COURGETTE_ENCODED_PROGRAM_H_
7
8#include <vector>
9
10#include "base/basictypes.h"
[email protected]423a3812011-10-26 00:50:2011#include "courgette/disassembler.h"
[email protected]fbd31eb2011-03-01 00:19:0212#include "courgette/memory_allocator.h"
[email protected]a8e80412013-07-18 22:07:5313#include "courgette/types_elf.h"
[email protected]f76b3b02009-05-06 04:02:1014
15namespace courgette {
16
17class SinkStream;
18class SinkStreamSet;
19class SourceStreamSet;
20
21// An EncodedProgram is a set of tables that contain a simple 'binary assembly
22// language' that can be assembled to produce a sequence of bytes, for example,
23// a Windows 32-bit executable.
24//
25class EncodedProgram {
26 public:
27 EncodedProgram();
28 ~EncodedProgram();
29
30 // Generating an EncodedProgram:
31 //
32 // (1) The image base can be specified at any time.
33 void set_image_base(uint64 base) { image_base_ = base; }
34
35 // (2) Address tables and indexes defined first.
[email protected]43a9e242011-04-06 17:42:4536 CheckBool DefineRel32Label(int index, RVA address) WARN_UNUSED_RESULT;
37 CheckBool DefineAbs32Label(int index, RVA address) WARN_UNUSED_RESULT;
[email protected]f76b3b02009-05-06 04:02:1038 void EndLabels();
39
40 // (3) Add instructions in the order needed to generate bytes of file.
[email protected]43a9e242011-04-06 17:42:4541 // NOTE: If any of these methods ever fail, the EncodedProgram instance
42 // has failed and should be discarded.
43 CheckBool AddOrigin(RVA rva) WARN_UNUSED_RESULT;
pkasting8e3a26a2014-10-03 18:52:2944 CheckBool AddCopy(size_t count, const void* bytes) WARN_UNUSED_RESULT;
[email protected]43a9e242011-04-06 17:42:4545 CheckBool AddRel32(int label_index) WARN_UNUSED_RESULT;
[email protected]2b637b62013-08-01 00:11:2446 CheckBool AddRel32ARM(uint16 op, int label_index) WARN_UNUSED_RESULT;
[email protected]43a9e242011-04-06 17:42:4547 CheckBool AddAbs32(int label_index) WARN_UNUSED_RESULT;
wfhfde55c72015-03-13 04:24:1948 CheckBool AddAbs64(int label_index) WARN_UNUSED_RESULT;
[email protected]11336c02013-09-25 19:05:5149 CheckBool AddPeMakeRelocs(ExecutableType kind) WARN_UNUSED_RESULT;
[email protected]4b3d192b2011-11-08 20:32:2650 CheckBool AddElfMakeRelocs() WARN_UNUSED_RESULT;
[email protected]a8e80412013-07-18 22:07:5351 CheckBool AddElfARMMakeRelocs() WARN_UNUSED_RESULT;
[email protected]f76b3b02009-05-06 04:02:1052
53 // (3) Serialize binary assembly language tables to a set of streams.
[email protected]43a9e242011-04-06 17:42:4554 CheckBool WriteTo(SinkStreamSet* streams) WARN_UNUSED_RESULT;
[email protected]f76b3b02009-05-06 04:02:1055
56 // Using an EncodedProgram to generate a byte stream:
57 //
58 // (4) Deserializes a fresh EncodedProgram from a set of streams.
[email protected]c8240b12011-03-22 20:19:4959 bool ReadFrom(SourceStreamSet* streams);
[email protected]f76b3b02009-05-06 04:02:1060
61 // (5) Assembles the 'binary assembly language' into final file.
[email protected]43a9e242011-04-06 17:42:4562 CheckBool AssembleTo(SinkStream* buffer) WARN_UNUSED_RESULT;
[email protected]f76b3b02009-05-06 04:02:1063
64 private:
[email protected]54f1b822009-07-18 03:28:4065 // Binary assembly language operations.
[email protected]4b3d192b2011-11-08 20:32:2666 // These are part of the patch format. Reusing an existing value will
67 // break backwards compatibility.
[email protected]54f1b822009-07-18 03:28:4068 enum OP {
[email protected]4b3d192b2011-11-08 20:32:2669 ORIGIN = 0, // ORIGIN <rva> - set address for subsequent assembly.
70 COPY = 1, // COPY <count> <bytes> - copy bytes to output.
71 COPY1 = 2, // COPY1 <byte> - same as COPY 1 <byte>.
72 REL32 = 3, // REL32 <index> - emit rel32 encoded reference to address at
73 // address table offset <index>
74 ABS32 = 4, // ABS32 <index> - emit abs32 encoded reference to address at
75 // address table offset <index>
76 MAKE_PE_RELOCATION_TABLE = 5, // Emit PE base relocation table blocks.
[email protected]a8e80412013-07-18 22:07:5377 MAKE_ELF_RELOCATION_TABLE = 6, // Emit Elf relocation table for X86
78 MAKE_ELF_ARM_RELOCATION_TABLE = 7, // Emit Elf relocation table for ARM
[email protected]11336c02013-09-25 19:05:5179 MAKE_PE64_RELOCATION_TABLE = 8, // Emit PE64 base relocation table blocks.
wfhfde55c72015-03-13 04:24:1980 ABS64 = 9, // ABS64 <index> - emit abs64 encoded reference to address at
81 // address table offset <index>
[email protected]2b637b62013-08-01 00:11:2482 // ARM reserves 0x1000-LAST_ARM, bits 13-16 define the opcode
83 // subset, and 1-12 are the compressed ARM op.
84 REL32ARM8 = 0x1000,
85 REL32ARM11 = 0x2000,
86 REL32ARM24 = 0x3000,
87 REL32ARM25 = 0x4000,
88 REL32ARM21 = 0x5000,
89 LAST_ARM = 0x5FFF,
[email protected]54f1b822009-07-18 03:28:4090 };
[email protected]f76b3b02009-05-06 04:02:1091
[email protected]43a9e242011-04-06 17:42:4592 typedef NoThrowBuffer<RVA> RvaVector;
pkasting8e3a26a2014-10-03 18:52:2993 typedef NoThrowBuffer<size_t> SizeTVector;
[email protected]43a9e242011-04-06 17:42:4594 typedef NoThrowBuffer<uint32> UInt32Vector;
95 typedef NoThrowBuffer<uint8> UInt8Vector;
96 typedef NoThrowBuffer<OP> OPVector;
[email protected]fbd31eb2011-03-01 00:19:0297
[email protected]f76b3b02009-05-06 04:02:1098 void DebuggingSummary();
[email protected]11336c02013-09-25 19:05:5199 CheckBool GeneratePeRelocations(SinkStream *buffer,
100 uint8 type) WARN_UNUSED_RESULT;
[email protected]a8e80412013-07-18 22:07:53101 CheckBool GenerateElfRelocations(Elf32_Word pending_elf_relocation_table,
102 SinkStream *buffer) WARN_UNUSED_RESULT;
[email protected]43a9e242011-04-06 17:42:45103 CheckBool DefineLabelCommon(RvaVector*, int, RVA) WARN_UNUSED_RESULT;
[email protected]fbd31eb2011-03-01 00:19:02104 void FinishLabelsCommon(RvaVector* addresses);
[email protected]f76b3b02009-05-06 04:02:10105
[email protected]2b637b62013-08-01 00:11:24106 // Decodes and evaluates courgette ops for ARM rel32 addresses.
107 CheckBool EvaluateRel32ARM(OP op, size_t& ix_rel32_ix, RVA& current_rva,
108 SinkStream* output);
109
[email protected]f76b3b02009-05-06 04:02:10110 // Binary assembly language tables.
111 uint64 image_base_;
[email protected]fbd31eb2011-03-01 00:19:02112 RvaVector rel32_rva_;
113 RvaVector abs32_rva_;
114 OPVector ops_;
115 RvaVector origins_;
pkasting8e3a26a2014-10-03 18:52:29116 SizeTVector copy_counts_;
[email protected]fbd31eb2011-03-01 00:19:02117 UInt8Vector copy_bytes_;
118 UInt32Vector rel32_ix_;
119 UInt32Vector abs32_ix_;
[email protected]f76b3b02009-05-06 04:02:10120
121 // Table of the addresses containing abs32 relocations; computed during
122 // assembly, used to generate base relocation table.
[email protected]fbd31eb2011-03-01 00:19:02123 UInt32Vector abs32_relocs_;
[email protected]f76b3b02009-05-06 04:02:10124
125 DISALLOW_COPY_AND_ASSIGN(EncodedProgram);
126};
127
128} // namespace courgette
[email protected]54f1b822009-07-18 03:28:40129#endif // COURGETTE_ENCODED_PROGRAM_H_