2016-05-14 4 views
0

Я пытаюсь скопировать массив A в массив B. Вот мой файл cpp.nasm 64, segmentation fault

#include <stdio.h> 

using namespace std; 

void copy(int * to, int * from, unsigned int n); //_Z6copyPiS_j 

int main(){ 
    int * a = new int [4]; 
    int * b = new int [4]; 
    for (int i=0;i<4;++i) 
    { 
    a[i] = i+1; 
    } 
    kopiuj(b,a,4); 
    for (int i=0;i<4;++i) 
    { 
    printf("%d - ", b[i]); 
    } 
    delete(a); 
    delete(b); 
    return 0; 
} 

и вот мой ASM файл с реализацией функции копирования

BITS 64 
section .text 

global _Z6kopiujPiS_j 

_Z6kopiujPiS_j:     

push rbp 
mov rbp, rsp 
cld 
mov edi, dword [rbp+8] ; destination 
mov esi, dword [rbp+12] ; source 
mov ecx, dword [rbp+16] ; size 

rep movsd; repeat ecx times 


mov rsp, rbp 
pop rbp 
ret      

вот как я скомпилировать его. К сожалению, это должно быть 64 бит. (Требование упражнения)

// nasm -felf64 82.asm -o 82.o 
// g++ -m64 -o 82m.o -c 82m.cpp 
// g++ -m64 82m.o 82.o -o 82 

и на rep movsd я получаю ошибки сегментации. Что я делаю неправильно?

+0

64bit == указатели - 8 байтов: Почему ebp + 8/12/16..those 4 друг от друга? И какое вызовное соглашение передает первые три аргумента через стек? – ABuckau

ответ

3

Вы, кажется, считаете, что параметры передаются в стек. Общие соглашения о вызовах для x64 используют регистры для первых нескольких параметров. См. Why does Windows64 use a different calling convention from all other OSes on x86-64?. (Или посмотрите на сгенерированную сборку для вызова, чтобы увидеть, как передаются параметры.)

+0

Спасибо, это была моя ошибка. Сначала я написал программу для 32 бит, а затем попытался преобразовать ее в 64 и полностью забыл о согласии. –