From c063b2467caaa5b4d9c9318df73c6c7cd7b954b6 Mon Sep 17 00:00:00 2001 From: wwylele Date: Tue, 16 Aug 2016 11:50:03 +0800 Subject: [PATCH] LDR fixup VAddr data address --- src/core/hle/service/ldr_ro.cpp | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/core/hle/service/ldr_ro.cpp b/src/core/hle/service/ldr_ro.cpp index 1df874958..f72262f77 100644 --- a/src/core/hle/service/ldr_ro.cpp +++ b/src/core/hle/service/ldr_ro.cpp @@ -650,11 +650,12 @@ class CROHelper final { * @param data_segment_size the buffer size for .data segment * @param bss_segment_address the buffer address for .bss segment * @param bss_segment_size the buffer size for .bss segment - * @returns ResultVal with the previous data segment offset before rebasing. + * @returns ResultVal with the virtual address of .data segment in CRO. */ - ResultVal RebaseSegmentTable(u32 cro_size, + ResultVal RebaseSegmentTable(u32 cro_size, VAddr data_segment_address, u32 data_segment_size, VAddr bss_segment_address, u32 bss_segment_size) { + u32 prev_data_segment = 0; u32 segment_num = GetField(SegmentNum); for (u32 i = 0; i < segment_num; ++i) { @@ -680,7 +681,7 @@ class CROHelper final { } SetEntry(i, segment); } - return MakeResult(prev_data_segment); + return MakeResult(prev_data_segment + module_address); } /** @@ -1592,7 +1593,6 @@ public: } prev_data_segment_address = *result_val; } - prev_data_segment_address += module_address; result = RebaseExportNamedSymbolTable(); if (result.IsError()) {