Compare commits
No commits in common. "a0e9ccb0e31f97ec9e7d11a1e1fc150a7f275d13" and "d1c86e7165b04e01efe13e93761502769b9cdfec" have entirely different histories.
a0e9ccb0e3
...
d1c86e7165
|
@ -18,8 +18,7 @@ void ft_lstdelone(t_list *lst, void (*del)(void *))
|
||||||
return ;
|
return ;
|
||||||
if (del)
|
if (del)
|
||||||
{
|
{
|
||||||
del(lst->content);
|
|
||||||
free(lst);
|
free(lst);
|
||||||
|
del(lst->content);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1 +0,0 @@
|
||||||
nasm -f elf64 -o print.o print.s && ld -o print print.o && nasm -f bin -o payload print.s && hexdump -v -e '"\\\x\" 1/1 "%02x"' payload
|
|
|
@ -48,5 +48,4 @@ int prepare_injection(t_elf_content *woody);
|
||||||
// encrypt.c
|
// encrypt.c
|
||||||
void encrypt(char *file, unsigned long int offset, unsigned long int size);
|
void encrypt(char *file, unsigned long int offset, unsigned long int size);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
7
print.s
7
print.s
|
@ -9,7 +9,7 @@ _start:
|
||||||
|
|
||||||
mov rdi, 1
|
mov rdi, 1
|
||||||
lea rsi, [rel msg]
|
lea rsi, [rel msg]
|
||||||
mov rdx, 14
|
mov rdx, 10
|
||||||
mov rax, 1
|
mov rax, 1
|
||||||
syscall
|
syscall
|
||||||
pop rdx
|
pop rdx
|
||||||
|
@ -17,7 +17,6 @@ _start:
|
||||||
pop rdi
|
pop rdi
|
||||||
pop rax
|
pop rax
|
||||||
jmp 0x00000000
|
jmp 0x00000000
|
||||||
|
msg db "..WOODY..",10
|
||||||
msg db "....WOODY....",10
|
|
||||||
text_section dq 0xbabababababababa
|
text_section dq 0xbabababababababa
|
||||||
section_sisze dq 0xcacacacacacacaca
|
section_sisze dq 0xcacacacacacacaca
|
|
@ -42,5 +42,4 @@ int main(int ac, char **av)
|
||||||
if (ret == EXIT_FAILURE)
|
if (ret == EXIT_FAILURE)
|
||||||
return ret;
|
return ret;
|
||||||
return prepare_injection(&woody);
|
return prepare_injection(&woody);
|
||||||
}
|
}
|
||||||
|
|
13
srcs/woody.c
13
srcs/woody.c
|
@ -1,5 +1,6 @@
|
||||||
#include "../includes/woody.h"
|
#include "../includes/woody.h"
|
||||||
|
|
||||||
|
|
||||||
int elf_magic_numbers(char *str)
|
int elf_magic_numbers(char *str)
|
||||||
{
|
{
|
||||||
return (!ft_strncmp(str, ELFMAG, SELFMAG));
|
return (!ft_strncmp(str, ELFMAG, SELFMAG));
|
||||||
|
@ -110,14 +111,14 @@ int insert_payload(t_elf_content *woody, t_payload *payload, size_t payload_posi
|
||||||
printf("the jump = %ld\n", payload->len - 16);
|
printf("the jump = %ld\n", payload->len - 16);
|
||||||
|
|
||||||
int32_t jmp_index = ptr_jmp - payload->payload;
|
int32_t jmp_index = ptr_jmp - payload->payload;
|
||||||
int32_t jump_value = ((payload_position + jmp_index + 5) - woody->Ehdr->e_entry) * -1; // 5 = JUMP SIZE (OPCODE + 4 bytes operand)
|
int32_t jump_value = (payload_position - woody->Ehdr->e_entry + jmp_index - 1) * -1;
|
||||||
ft_memcpy(&payload->payload[jmp_index + 1], &jump_value, sizeof(jump_value));
|
ft_memcpy(&payload->payload[jmp_index + 1], &jump_value, sizeof(jump_value));
|
||||||
|
|
||||||
int64_t text_index = ptr_text_section - payload->payload;
|
int64_t text_index = ptr_text_section - payload->payload;
|
||||||
int64_t text_value = (payload_position - woody->text_section->sh_offset + text_index - 1) * -1;
|
int64_t text_value = (payload_position - woody->text_section->sh_offset + text_index - 1) * -1;
|
||||||
text_value = 0;
|
text_value = 0;
|
||||||
ft_memcpy(&payload->payload[text_index], &text_value, sizeof(text_value));
|
ft_memcpy(&payload->payload[text_index], &text_value, sizeof(text_value));
|
||||||
|
|
||||||
int64_t section_index = ptr_section_size - payload->payload;
|
int64_t section_index = ptr_section_size - payload->payload;
|
||||||
int64_t section_value = (payload_position - woody->text_section->sh_size + section_index - 1) * -1;
|
int64_t section_value = (payload_position - woody->text_section->sh_size + section_index - 1) * -1;
|
||||||
ft_memcpy(&payload->payload[section_index], §ion_value, sizeof(section_value));
|
ft_memcpy(&payload->payload[section_index], §ion_value, sizeof(section_value));
|
||||||
|
@ -126,7 +127,7 @@ int insert_payload(t_elf_content *woody, t_payload *payload, size_t payload_posi
|
||||||
printf("Old entry : %ld (%lx)\n", woody->Ehdr->e_entry, woody->Ehdr->e_entry);
|
printf("Old entry : %ld (%lx)\n", woody->Ehdr->e_entry, woody->Ehdr->e_entry);
|
||||||
printf("Code cave start = %ld (%lx)\n", payload_position, payload_position);
|
printf("Code cave start = %ld (%lx)\n", payload_position, payload_position);
|
||||||
printf("Payload size = %ld (%lx)\n", payload->len, payload->len);
|
printf("Payload size = %ld (%lx)\n", payload->len, payload->len);
|
||||||
printf("Backward offset = %d (%x)(%x)\n", jump_value, jump_value, -jump_value);
|
printf("Backwar d offset = %d (%x)(%x)\n", jump_value, jump_value, -jump_value);
|
||||||
return EXIT_SUCCESS;
|
return EXIT_SUCCESS;
|
||||||
}
|
}
|
||||||
return EXIT_FAILURE;
|
return EXIT_FAILURE;
|
||||||
|
@ -135,9 +136,9 @@ int insert_payload(t_elf_content *woody, t_payload *payload, size_t payload_posi
|
||||||
void inject(t_elf_content *woody)
|
void inject(t_elf_content *woody)
|
||||||
{
|
{
|
||||||
t_payload *payload = get_payload();
|
t_payload *payload = get_payload();
|
||||||
int i = get_load_segment(woody, 0, true);
|
int i = get_load_segment(woody, 0, true);
|
||||||
int j = get_load_segment(woody, i + 1, false);
|
int j = get_load_segment(woody, i + 1, false);
|
||||||
|
|
||||||
size_t code_cave_size = woody->Phdr[j].p_offset - (woody->Phdr[i].p_offset + woody->Phdr[i].p_filesz);
|
size_t code_cave_size = woody->Phdr[j].p_offset - (woody->Phdr[i].p_offset + woody->Phdr[i].p_filesz);
|
||||||
size_t payload_position;
|
size_t payload_position;
|
||||||
printf("load position = : %ld (%lx)\n", woody->Phdr[i].p_offset, woody->Phdr[i].p_offset);
|
printf("load position = : %ld (%lx)\n", woody->Phdr[i].p_offset, woody->Phdr[i].p_offset);
|
||||||
|
@ -204,7 +205,6 @@ int get_elf_sections(t_elf_content *woody)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return EXIT_SUCCESS;
|
return EXIT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -224,4 +224,3 @@ int prepare_injection(t_elf_content *woody)
|
||||||
free(woody_file);
|
free(woody_file);
|
||||||
return EXIT_SUCCESS;
|
return EXIT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue