Как изменить точку входа программы на языке C, скомпилированной с помощью gcc?
Как и в следующем коде
#include<stdio.h>
int entry() //entry is the entry point instead of main
{
return 0;
}
Как изменить точку входа программы на языке C, скомпилированной с помощью gcc?
Как и в следующем коде
#include<stdio.h>
int entry() //entry is the entry point instead of main
{
return 0;
}
Это установка компоновщика:
-Wl,-eentry
объект -Wl,... передает аргументы компоновщику, а компоновщик принимает аргумент -e для установки функции ввода
Вы можете изменить исходный код следующим образом:
#include<stdio.h>
const char my_interp[] __attribute__((section(".interp"))) = "/lib/ld-linux.so.2";
int entry() //entry is the entry point instead of main
{
exit(0);
}
Раздел ".interp" позволит вашей программе вызывать внешнюю общую библиотеку. Вызов exit приведет к тому, что ваша функция входа выйдет из программы вместо возврата.
Затем создайте программу как исполняемую библиотеку:
$ gcc -shared -fPIC -e entry test_main.c -o test_main.so
$ ./test_main
Если вы находитесь в системе, которая предоставляет GNU Binutils (например, Linux),
вы можете использовать команду objcopy
сделать произвольную функцию новой точкой входа.
Предположим, что файл с именем program.c, содержащий функцию entry:
$ cat > program.c
#include <stdio.h>
int entry()
{
return 0;
}
^D
Сначала вы скомпилируете его с помощью -c для создания перемещаемого объектного файла:
$ gcc -c program.c -o program.o
Затем вы переопределяете entry как main:
$ objcopy --redefine-sym entry=main program.o
Теперь используйте gcc для компиляции нового объектного файла:
$ gcc program.o -o program
ПРИМЕЧАНИЕ. Если ваша программа уже имеет функцию под названием main, перед шагом 2 вы можете выполнить отдельный вызов objcopy:
objcopy --redefine-sym oldmain=main program.o