Вопрос:

Кто-нибудь смог создать гибрид PE COFF и ELF?

linux winapi binary elf coff

2292 просмотра

3 ответа

5686 Репутация автора

Я имею в виду, может ли один двоичный файл работать в Win32 и Linux i386?

Автор: est Источник Размещён: 17.01.2010 07:43

Ответы (3)


-1 плюса

17868 Репутация автора

Конечно. Используйте Java.

Автор: Richard Pennington Размещён: 17.01.2010 07:48

2 плюса

17785 Репутация автора

Два формата достаточно различны, так что гибрид маловероятен.

Тем не менее, Linux поддерживает загрузку различных исполняемых форматов с помощью «интерпретатора». Таким образом, скомпилированные .exeфайлы, содержащие CIL (скомпилированный C # или другие языки .NET), могут выполняться, например, непосредственно под Linux.

Автор: Jakob Borg Размещён: 17.01.2010 07:49

21 плюса

200316 Репутация автора

Решение

Это невозможно, потому что два типа имеют конфликтующие форматы:

  • Первые два символа PE-файла должны быть 'M' 'Z';
  • Первые четыре символа файла ELF должны быть '\x7f' 'E' 'L' 'F'.

Очевидно, что вы не можете создать один файл, который удовлетворяет обоим форматам.


В ответ на комментарий о двоичном файле polyglot, допустимом и как 16-битный COM-файл, и как ELF-файл Linux, это возможно (хотя на самом деле COM-файл - это программа DOS, а не Windows - и, конечно, не Win32).

Вот один, который я собрал вместе - скомпилируйте его с помощью NASM. Это работает, потому что первые два байта файла ELF ( '\x7f' 'E') также являются допустимым машинным кодом 8086 (45-байтная относительная инструкция перехода, если больше, чем). Минимальные заголовки ELF, полученные от Брайана Райтера .

BITS 32
ORG 0x08048000

  ehdr:                                                 ; Elf32_Ehdr
                db      0x7F, "ELF", 1, 1, 1, 0         ;   e_ident
        times 8 db      0
                dw      2                               ;   e_type
                dw      3                               ;   e_machine
                dd      1                               ;   e_version
                dd      _start                          ;   e_entry
                dd      phdr - $$                       ;   e_phoff
                dd      0                               ;   e_shoff
                dd      0                               ;   e_flags
                dw      ehdrsize                        ;   e_ehsize
                dw      phdrsize                        ;   e_phentsize
                dw      1                               ;   e_phnum
                dw      0                               ;   e_shentsize
                dw      0                               ;   e_shnum
                dw      0                               ;   e_shstrndx
  ehdrsize      equ     $ - ehdr

times 0x47-($-$$) db    0

; DOS COM File code
BITS 16
    mov dx, msg1 - $$ + 0x100
    mov ah, 0x09
    int 0x21
    mov ah, 0x00
    int 0x21
  msg1:         db      `Hello World (DOS).\r\n$`

BITS 32
  phdr:                                                 ; Elf32_Phdr
                dd      1                               ;   p_type
                dd      0                               ;   p_offset
                dd      $$                              ;   p_vaddr
                dd      $$                              ;   p_paddr
                dd      filesize                        ;   p_filesz
                dd      filesize                        ;   p_memsz
                dd      5                               ;   p_flags
                dd      0x1000                          ;   p_align
  phdrsize      equ     $ - phdr

; Linux ELF code
  _start:
    mov eax, 4      ; SYS_write
    mov ebx, 1      ; stdout
    mov ecx, msg2
    mov edx, msg2_len
    int 0x80
    mov eax, 1      ; SYS_exit
    mov ebx, 0
    int 0x80
  msg2:         db      `Hello World (Linux).\n`
  msg2_len      equ     $ - msg2

  filesize      equ     $ - $$
Автор: caf Размещён: 17.01.2010 11:52
Вопросы из категории :
32x32