微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

从Linux到Windows的C ++

如何解决从Linux到Windows的C ++

我目前正在从Linux到Windows重建我的项目,我在重建功能上没有什么问题,我在Linux上经验丰富,我不知道如何重建您看到的评论

唯一的问题是

 mprotect(page,mprot_len,PROT_READ | PROT_WRITE | PROT_EXEC)

这是我的代码,我不知道替换它

class BytePatch
{
    void *addr{ 0 };
    size_t size;
    std::vector<unsigned char> patch_bytes;
    std::vector<unsigned char> original;
    bool patched{ false };

public:
    ~BytePatch()
    {
        Shutdown();
    }
    BytePatch(std::function<uintptr_t(const char *)> SigScanFunc,const char *pattern,size_t offset,std::vector<unsigned char> patch) : patch_bytes{ patch }
    {
        addr = (void *) SigScanFunc(pattern);
        if (!addr)
        {
            logging::Info("Signature not found");
            throw std::runtime_error("Signature not found");
        }
        addr = static_cast<void *>(static_cast<char *>(addr) + offset);
        size = patch.size();
        original.resize(size);
        memcpy(&original[0],addr,size);
    }
    BytePatch(uintptr_t addr,std::vector<unsigned char> patch) : addr{ reinterpret_cast<void *>(addr) },patch_bytes{ patch }
    {
        size = patch.size();
        original.resize(size);
        memcpy(&original[0],reinterpret_cast<void *>(addr),size);
    }
    BytePatch(void *addr,std::vector<unsigned char> patch) : addr{ addr },size);
    }

    void Patch()
    {
        if (!patched)
        {
            void *page          = (void *) ((uint64_t) addr & ~0xFFF);
            void *end_page      = (void *) (((uint64_t)(addr) + size) & ~0xFFF);
            uintptr_t mprot_len = (uint64_t) end_page - (uint64_t) page + 0xFFF;

            mprotect(page,PROT_READ | PROT_WRITE | PROT_EXEC); // this one 
            memcpy(addr,&patch_bytes[0],size);
            mprotect(page,PROT_EXEC); // this one 
            patched = true;
        }
    }
    void Shutdown()
    {
        if (patched)
        {
            void *page          = (void *) ((uint64_t) addr & ~0xFFF);
            void *end_page      = (void *) (((uint64_t)(addr) + size) & ~0xFFF);
            uintptr_t mprot_len = (uint64_t) end_page - (uint64_t) page + 0xFFF;

            mprotect(page,PROT_READ | PROT_WRITE | PROT_EXEC); // this one
            memcpy(addr,&original[0],PROT_EXEC); // this one
            patched = false;
        }
    }
};

预先感谢人们

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。