/* This file is part of Fennix Kernel. Fennix Kernel is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. Fennix Kernel is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with Fennix Kernel. If not, see . */ #include #include "../../../kernel.h" namespace Execute { std::vector ELFGetSections(Node fd, const char *SectionName) { std::vector ret; Elf_Ehdr ehdr; fs->Read(fd, &ehdr, sizeof(Elf_Ehdr), 0); std::unique_ptr sections(new Elf_Shdr[ehdr.e_shnum]); fs->Read(fd, sections.get(), sizeof(Elf_Shdr) * ehdr.e_shnum, ehdr.e_shoff); std::string sectionNames(sections[ehdr.e_shstrndx].sh_size, '\0'); fs->Read(fd, sectionNames.data(), sections[ehdr.e_shstrndx].sh_size, sections[ehdr.e_shstrndx].sh_offset); for (Elf_Half i = 0; i < ehdr.e_shnum; ++i) { const char *Name = sectionNames.data() + sections[i].sh_name; if (strcmp(Name, SectionName) == 0) ret.push_back(sections[i]); } return ret; } }