我需要帮助来反转函数的功能

I need help reversing what a function does

本文关键字:函数 功能 帮助      更新时间:2023-10-16

所以我得到了这个函数。

UINT32 Encrypt(UINT32 instruction, int increment)
{
    UINT32 linstruction = _rotl(instruction, 7);
    UINT32 rinstruction = _rotr(instruction, 3);
    UINT32 key = (0x1F3D8AF * increment) ^ (rinstruction ^ linstruction);
    return (key ^ instruction);
}

我需要创建一个函数来实际解密它并使用密钥从结果中获取指令,所以它会像这样。

t = encrypt(t, i);
t = decrypt(t, key);

基本上,我希望它反转加密的整个过程,以便对其进行解密并获取指令。

它们用于此函数

int RbxOpEncoder::encode(Instruction op, int i, int key) {
    int orig = ConvertInstruction(op);
    int t = orig;
    switch (GET_OPCODE(op)) {
    case OP_JMP:
        t = ((Encrypt(t, i) & 0x3FFFFFF) | ((orig >> 26 & MASK1(6, 0)) << 0x1A));
    break;
    case OP_CALL:
    case OP_TAILCALL:
    case OP_CLOSURE:
    case OP_RETURN:
        t = ((Calldecrypt(t, i) & 0x3FFFFFF) | ((orig >> 26 & MASK1(6, 0)) << 0x1A));
        break;  
    }
    t = EncryptOpcode(t, key);
    return t;
}
您可以使用

std::uint32_t decrypt(std::uint32_t instruction, int increment)
{
    instruction = instruction ^ (0x1F3D8AF * increment);
    for (int i = 0; i != 15; ++i) {
        instruction = Encrypt(instruction, 0);
    }
    return instruction;
}

然后你有

decrypt(Encrypt(value, increment), increment) == value

演示