/*
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;
}
}