iced/Iced.UnitTests/Intel/EncoderTests/BlockEncoderTest64_jmp.cs

217 lines
7.2 KiB
C#
Raw Normal View History

2018-09-06 02:02:48 +02:00
/*
2019-01-01 12:10:41 +01:00
Copyright (C) 2018-2019 de4dot@gmail.com
2018-09-06 02:02:48 +02:00
This file is part of Iced.
Iced is free software: you can redistribute it and/or modify
it under the terms of the GNU Lesser General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
Iced is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public License
along with Iced. If not, see <https://www.gnu.org/licenses/>.
*/
#if !NO_ENCODER
using System;
using Iced.Intel;
using Xunit;
namespace Iced.UnitTests.Intel.EncoderTests {
public sealed class BlockEncoderTest64_jmp : BlockEncoderTest {
const int bitness = 64;
const ulong origRip = 0x8000;
const ulong newRip = 0x8000000000000000;
[Fact]
void Jmp_fwd() {
var originalData = new byte[] {
/*0000*/ 0xB0, 0x00,// mov al,0
/*0002*/ 0xEB, 0x09,// jmp short 000000000000800Dh
/*0004*/ 0xB0, 0x01,// mov al,1
/*0006*/ 0xE9, 0x02, 0x00, 0x00, 0x00,// jmp near ptr 000000000000800Dh
/*000B*/ 0xB0, 0x02,// mov al,2
/*000D*/ 0x90,// nop
};
var newData = new byte[] {
/*0000*/ 0xB0, 0x00,// mov al,0
/*0002*/ 0xEB, 0x06,// jmp short 800000000000000Ah
/*0004*/ 0xB0, 0x01,// mov al,1
/*0006*/ 0xEB, 0x02,// jmp short 800000000000000Ah
/*0008*/ 0xB0, 0x02,// mov al,2
/*000A*/ 0x90,// nop
};
var expectedInstructionOffsets = new uint[] {
0x0000,
0x0002,
0x0004,
0x0006,
0x0008,
0x000A,
};
var expectedRelocInfos = Array.Empty<RelocInfo>();
const BlockEncoderOptions options = BlockEncoderOptions.None;
2018-09-25 21:26:05 +02:00
EncodeBase(bitness, origRip, originalData, newRip, newData, options, decoderOptions, expectedInstructionOffsets, expectedRelocInfos);
2018-09-06 02:02:48 +02:00
}
[Fact]
void Jmp_bwd() {
var originalData = new byte[] {
/*0000*/ 0x90,// nop
/*0001*/ 0xB0, 0x00,// mov al,0
/*0003*/ 0xEB, 0xFB,// jmp short 0000000000008000h
/*0005*/ 0xB0, 0x01,// mov al,1
/*0007*/ 0xE9, 0xF4, 0xFF, 0xFF, 0xFF,// jmp near ptr 0000000000008000h
/*000C*/ 0xB0, 0x02,// mov al,2
};
var newData = new byte[] {
/*0000*/ 0x90,// nop
/*0001*/ 0xB0, 0x00,// mov al,0
/*0003*/ 0xEB, 0xFB,// jmp short 8000000000000000h
/*0005*/ 0xB0, 0x01,// mov al,1
/*0007*/ 0xEB, 0xF7,// jmp short 8000000000000000h
/*0009*/ 0xB0, 0x02,// mov al,2
};
var expectedInstructionOffsets = new uint[] {
0x0000,
0x0001,
0x0003,
0x0005,
0x0007,
0x0009,
};
var expectedRelocInfos = Array.Empty<RelocInfo>();
const BlockEncoderOptions options = BlockEncoderOptions.None;
2018-09-25 21:26:05 +02:00
EncodeBase(bitness, origRip, originalData, newRip, newData, options, decoderOptions, expectedInstructionOffsets, expectedRelocInfos);
2018-09-06 02:02:48 +02:00
}
[Fact]
void Jmp_other_short() {
var originalData = new byte[] {
/*0000*/ 0xB0, 0x00,// mov al,0
/*0002*/ 0xEB, 0x09,// jmp short 000000000000800Dh
/*0004*/ 0xB0, 0x01,// mov al,1
/*0006*/ 0xE9, 0x02, 0x00, 0x00, 0x00,// jmp near ptr 000000000000800Dh
/*000B*/ 0xB0, 0x02,// mov al,2
};
var newData = new byte[] {
/*0000*/ 0xB0, 0x00,// mov al,0
/*0002*/ 0xEB, 0x0A,// jmp short 000000000000800Dh
/*0004*/ 0xB0, 0x01,// mov al,1
/*0006*/ 0xEB, 0x06,// jmp short 000000000000800Dh
/*0008*/ 0xB0, 0x02,// mov al,2
};
var expectedInstructionOffsets = new uint[] {
0x0000,
0x0002,
0x0004,
0x0006,
0x0008,
};
var expectedRelocInfos = Array.Empty<RelocInfo>();
const BlockEncoderOptions options = BlockEncoderOptions.None;
2018-09-25 21:26:05 +02:00
EncodeBase(bitness, origRip, originalData, origRip - 1, newData, options, decoderOptions, expectedInstructionOffsets, expectedRelocInfos);
2018-09-06 02:02:48 +02:00
}
[Fact]
void Jmp_other_near() {
var originalData = new byte[] {
/*0000*/ 0xB0, 0x00,// mov al,0
/*0002*/ 0xEB, 0x09,// jmp short 000000000000800Dh
/*0004*/ 0xB0, 0x01,// mov al,1
/*0006*/ 0xE9, 0x02, 0x00, 0x00, 0x00,// jmp near ptr 000000000000800Dh
/*000B*/ 0xB0, 0x02,// mov al,2
};
var newData = new byte[] {
/*0000*/ 0xB0, 0x00,// mov al,0
/*0002*/ 0xE9, 0x06, 0xF0, 0xFF, 0xFF,// jmp near ptr 000000000000800Dh
/*0007*/ 0xB0, 0x01,// mov al,1
/*0009*/ 0xE9, 0xFF, 0xEF, 0xFF, 0xFF,// jmp near ptr 000000000000800Dh
/*000E*/ 0xB0, 0x02,// mov al,2
};
var expectedInstructionOffsets = new uint[] {
0x0000,
0x0002,
0x0007,
0x0009,
0x000E,
};
var expectedRelocInfos = Array.Empty<RelocInfo>();
const BlockEncoderOptions options = BlockEncoderOptions.None;
2018-09-25 21:26:05 +02:00
EncodeBase(bitness, origRip, originalData, origRip + 0x1000, newData, options, decoderOptions, expectedInstructionOffsets, expectedRelocInfos);
2018-09-06 02:02:48 +02:00
}
[Fact]
void Jmp_other_long() {
var originalData = new byte[] {
/*0000*/ 0xB0, 0x00,// mov al,0
/*0002*/ 0xEB, 0x09,// jmp short 123456789ABCDE0Dh
/*0004*/ 0xB0, 0x01,// mov al,1
/*0006*/ 0xE9, 0x03, 0x00, 0x00, 0x00,// jmp near ptr 123456789ABCDE0Eh
/*000B*/ 0xB0, 0x02,// mov al,2
};
var newData = new byte[] {
/*0000*/ 0xB0, 0x00,// mov al,0
/*0002*/ 0xFF, 0x25, 0x10, 0x00, 0x00, 0x00,// jmp qword ptr [8000000000000018h]
/*0008*/ 0xB0, 0x01,// mov al,1
/*000A*/ 0xFF, 0x25, 0x10, 0x00, 0x00, 0x00,// jmp qword ptr [8000000000000020h]
/*0010*/ 0xB0, 0x02,// mov al,2
/*0012*/ 0xCC, 0xCC, 0xCC, 0xCC, 0xCC, 0xCC,
/*0018*/ 0x0D, 0xDE, 0xBC, 0x9A, 0x78, 0x56, 0x34, 0x12,
/*0020*/ 0x0E, 0xDE, 0xBC, 0x9A, 0x78, 0x56, 0x34, 0x12,
};
var expectedInstructionOffsets = new uint[] {
0x0000,
uint.MaxValue,
0x0008,
uint.MaxValue,
0x0010,
};
var expectedRelocInfos = new RelocInfo[] {
new RelocInfo(RelocKind.Offset64, 0x8000000000000018),
new RelocInfo(RelocKind.Offset64, 0x8000000000000020),
};
const BlockEncoderOptions options = BlockEncoderOptions.None;
const ulong origRip = 0x123456789ABCDE00;
2018-09-25 21:26:05 +02:00
EncodeBase(bitness, origRip, originalData, newRip, newData, options, decoderOptions, expectedInstructionOffsets, expectedRelocInfos);
2018-09-06 02:02:48 +02:00
}
[Fact]
void Jmp_fwd_no_opt() {
var originalData = new byte[] {
/*0000*/ 0xB0, 0x00,// mov al,0
/*0002*/ 0xEB, 0x09,// jmp short 000000000000800Dh
/*0004*/ 0xB0, 0x01,// mov al,1
/*0006*/ 0xE9, 0x02, 0x00, 0x00, 0x00,// jmp near ptr 000000000000800Dh
/*000B*/ 0xB0, 0x02,// mov al,2
/*000D*/ 0x90,// nop
};
var newData = new byte[] {
/*0000*/ 0xB0, 0x00,// mov al,0
/*0002*/ 0xEB, 0x09,// jmp short 000000000000800Dh
/*0004*/ 0xB0, 0x01,// mov al,1
/*0006*/ 0xE9, 0x02, 0x00, 0x00, 0x00,// jmp near ptr 000000000000800Dh
/*000B*/ 0xB0, 0x02,// mov al,2
/*000D*/ 0x90,// nop
};
var expectedInstructionOffsets = new uint[] {
0x0000,
0x0002,
0x0004,
0x0006,
0x000B,
0x000D,
};
var expectedRelocInfos = Array.Empty<RelocInfo>();
const BlockEncoderOptions options = BlockEncoderOptions.DontFixBranches;
2018-09-25 21:26:05 +02:00
EncodeBase(bitness, origRip, originalData, newRip, newData, options, decoderOptions, expectedInstructionOffsets, expectedRelocInfos);
2018-09-06 02:02:48 +02:00
}
}
}
#endif