pcsx2/3rdparty/lzma/include/Bra.h

106 lines
3.6 KiB
C
Raw Permalink Normal View History

2022-05-12 07:48:39 +00:00
/* Bra.h -- Branch converters for executables
2024-11-01 23:04:27 +00:00
2024-01-20 : Igor Pavlov : Public domain */
2022-05-12 07:48:39 +00:00
2024-05-10 23:10:28 +00:00
#ifndef ZIP7_INC_BRA_H
#define ZIP7_INC_BRA_H
2022-05-12 07:48:39 +00:00
#include "7zTypes.h"
EXTERN_C_BEGIN
2024-11-01 23:04:27 +00:00
/* #define PPC BAD_PPC_11 // for debug */
#define Z7_BRANCH_CONV_DEC_2(name) z7_ ## name ## _Dec
#define Z7_BRANCH_CONV_ENC_2(name) z7_ ## name ## _Enc
#define Z7_BRANCH_CONV_DEC(name) Z7_BRANCH_CONV_DEC_2(BranchConv_ ## name)
#define Z7_BRANCH_CONV_ENC(name) Z7_BRANCH_CONV_ENC_2(BranchConv_ ## name)
2024-05-10 23:10:28 +00:00
#define Z7_BRANCH_CONV_ST_DEC(name) z7_BranchConvSt_ ## name ## _Dec
#define Z7_BRANCH_CONV_ST_ENC(name) z7_BranchConvSt_ ## name ## _Enc
#define Z7_BRANCH_CONV_DECL(name) Byte * name(Byte *data, SizeT size, UInt32 pc)
#define Z7_BRANCH_CONV_ST_DECL(name) Byte * name(Byte *data, SizeT size, UInt32 pc, UInt32 *state)
typedef Z7_BRANCH_CONV_DECL( (*z7_Func_BranchConv));
typedef Z7_BRANCH_CONV_ST_DECL((*z7_Func_BranchConvSt));
#define Z7_BRANCH_CONV_ST_X86_STATE_INIT_VAL 0
2024-11-01 23:04:27 +00:00
Z7_BRANCH_CONV_ST_DECL (Z7_BRANCH_CONV_ST_DEC(X86));
Z7_BRANCH_CONV_ST_DECL (Z7_BRANCH_CONV_ST_ENC(X86));
2024-05-10 23:10:28 +00:00
#define Z7_BRANCH_FUNCS_DECL(name) \
2024-11-01 23:04:27 +00:00
Z7_BRANCH_CONV_DECL (Z7_BRANCH_CONV_DEC_2(name)); \
Z7_BRANCH_CONV_DECL (Z7_BRANCH_CONV_ENC_2(name));
2024-05-10 23:10:28 +00:00
2024-11-01 23:04:27 +00:00
Z7_BRANCH_FUNCS_DECL (BranchConv_ARM64)
Z7_BRANCH_FUNCS_DECL (BranchConv_ARM)
Z7_BRANCH_FUNCS_DECL (BranchConv_ARMT)
Z7_BRANCH_FUNCS_DECL (BranchConv_PPC)
Z7_BRANCH_FUNCS_DECL (BranchConv_SPARC)
Z7_BRANCH_FUNCS_DECL (BranchConv_IA64)
Z7_BRANCH_FUNCS_DECL (BranchConv_RISCV)
2024-05-10 23:10:28 +00:00
2022-05-12 07:48:39 +00:00
/*
2024-05-10 23:10:28 +00:00
These functions convert data that contain CPU instructions.
Each such function converts relative addresses to absolute addresses in some
branch instructions: CALL (in all converters) and JUMP (X86 converter only).
Such conversion allows to increase compression ratio, if we compress that data.
There are 2 types of converters:
Byte * Conv_RISC (Byte *data, SizeT size, UInt32 pc);
Byte * ConvSt_X86(Byte *data, SizeT size, UInt32 pc, UInt32 *state);
Each Converter supports 2 versions: one for encoding
and one for decoding (_Enc/_Dec postfixes in function name).
2022-05-12 07:48:39 +00:00
2024-05-10 23:10:28 +00:00
In params:
data : data buffer
size : size of data
2024-11-01 23:04:27 +00:00
pc : current virtual Program Counter (Instruction Pointer) value
2024-05-10 23:10:28 +00:00
In/Out param:
state : pointer to state variable (for X86 converter only)
Return:
The pointer to position in (data) buffer after last byte that was processed.
If the caller calls converter again, it must call it starting with that position.
2024-11-01 23:04:27 +00:00
But the caller is allowed to move data in buffer. So pointer to
2024-05-10 23:10:28 +00:00
current processed position also will be changed for next call.
Also the caller must increase internal (pc) value for next call.
2022-05-12 07:48:39 +00:00
2024-05-10 23:10:28 +00:00
Each converter has some characteristics: Endian, Alignment, LookAhead.
2022-05-12 07:48:39 +00:00
Type Endian Alignment LookAhead
2024-05-10 23:10:28 +00:00
X86 little 1 4
2022-05-12 07:48:39 +00:00
ARMT little 2 2
2024-11-01 23:04:27 +00:00
RISCV little 2 6
2022-05-12 07:48:39 +00:00
ARM little 4 0
2024-05-10 23:10:28 +00:00
ARM64 little 4 0
2022-05-12 07:48:39 +00:00
PPC big 4 0
SPARC big 4 0
IA64 little 16 0
2024-05-10 23:10:28 +00:00
(data) must be aligned for (Alignment).
processed size can be calculated as:
SizeT processed = Conv(data, size, pc) - data;
if (processed == 0)
it means that converter needs more data for processing.
If (size < Alignment + LookAhead)
then (processed == 0) is allowed.
2022-05-12 07:48:39 +00:00
2024-05-10 23:10:28 +00:00
Example code for conversion in loop:
UInt32 pc = 0;
size = 0;
for (;;)
{
size += Load_more_input_data(data + size);
SizeT processed = Conv(data, size, pc) - data;
if (processed == 0 && no_more_input_data_after_size)
break; // we stop convert loop
data += processed;
size -= processed;
pc += processed;
}
2022-05-12 07:48:39 +00:00
*/
EXTERN_C_END
#endif