summaryrefslogtreecommitdiff
path: root/src/core/memory.cpp
diff options
context:
space:
mode:
authorGravatar wwylele2016-06-27 20:42:42 +0300
committerGravatar wwylele2016-08-27 21:38:06 +0800
commitb2df959733ee65cbf705dbfbd05761a06929a6b6 (patch)
tree90327dc0e58493de455fa4a4fdd4599ee8c6477a /src/core/memory.cpp
parentMerge pull request #2022 from MerryMage/issue-tpl (diff)
downloadyuzu-b2df959733ee65cbf705dbfbd05761a06929a6b6.tar.gz
yuzu-b2df959733ee65cbf705dbfbd05761a06929a6b6.tar.xz
yuzu-b2df959733ee65cbf705dbfbd05761a06929a6b6.zip
Memory: add ReadCString function
Diffstat (limited to 'src/core/memory.cpp')
-rw-r--r--src/core/memory.cpp14
1 files changed, 14 insertions, 0 deletions
diff --git a/src/core/memory.cpp b/src/core/memory.cpp
index 8c9e5d46d..9aa8c4e5a 100644
--- a/src/core/memory.cpp
+++ b/src/core/memory.cpp
@@ -280,6 +280,20 @@ u8* GetPointer(const VAddr vaddr) {
280 return nullptr; 280 return nullptr;
281} 281}
282 282
283std::string ReadCString(VAddr vaddr, std::size_t max_length) {
284 std::string string;
285 string.reserve(max_length);
286 for (std::size_t i = 0; i < max_length; ++i) {
287 char c = Read8(vaddr);
288 if (c == '\0')
289 break;
290 string.push_back(c);
291 ++vaddr;
292 }
293 string.shrink_to_fit();
294 return string;
295}
296
283u8* GetPhysicalPointer(PAddr address) { 297u8* GetPhysicalPointer(PAddr address) {
284 // TODO(Subv): This call should not go through the application's memory mapping. 298 // TODO(Subv): This call should not go through the application's memory mapping.
285 return GetPointer(PhysicalToVirtualAddress(address)); 299 return GetPointer(PhysicalToVirtualAddress(address));