From b858732b901a60231a5bdfe28591c958b745140d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Axel=20D=C3=B6rfler?= Date: Thu, 16 Oct 2003 18:28:10 +0000 Subject: [PATCH] Fixed a scoping bug in the elf_load_kspace() function (non-critical under normal circumstances, though). Updated the comment why we have to create the read-only segment as read-write. git-svn-id: file:///srv/svn/repos/haiku/trunk/current@5055 a95241bf-73f2-0310-859d-f6bbb57e9c96 --- src/kernel/core/elf.c | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/src/kernel/core/elf.c b/src/kernel/core/elf.c index cfa83a6071..8e5489bb7d 100644 --- a/src/kernel/core/elf.c +++ b/src/kernel/core/elf.c @@ -667,6 +667,8 @@ error: image_id elf_load_kspace(const char *path, const char *sym_prepend) { + bool ro_segment_handled = false; + bool rw_segment_handled = false; struct Elf32_Ehdr *eheader; struct Elf32_Phdr *pheaders; struct elf_image_info *image; @@ -749,8 +751,6 @@ elf_load_kspace(const char *path, const char *sym_prepend) for (i = 0; i < eheader->e_phnum; i++) { char region_name[64]; - bool ro_segment_handled = false; - bool rw_segment_handled = false; int image_region; int protection; @@ -787,8 +787,9 @@ elf_load_kspace(const char *path, const char *sym_prepend) ro_segment_handled = true; image_region = 0; protection = B_KERNEL_READ_AREA | B_KERNEL_WRITE_AREA; - // ToDo: why is this? Right now, the kernel crashes without - // it, so go, investigate! + // We need to read in the contents of this area later, + // so it has to be writeable at this point; + // ToDo: we should change the area protection later. sprintf(region_name, "%s_ro", path); } else {