2016-11-22 201 views
1

我正在开发一个项目,我目前在我的一行中遇到访问冲突。我想知道我是否可以对错在哪里得到第二个意见。这里是我的代码(注意,我在运行时出现错误,但它确实建):访问冲突MASM x86程序集

.data 
BlueTextOnGray = blue + (lightGray * 16) 
DefaultColor = lightGray + (black * 16) 
arrayD SDWORD 12345678h,1A4B2000h,3434h,7AB9h 

fib BYTE 1,2 
    BYTE NUMBER_FIBS_TO_COMPUTE dup(0) 

prompt BYTE "Enter an ending integer: ",0 
error BYTE "Invalid stopping point! 



.code 

main PROC 

    mov eax,BlueTextOnGray 
    call SetTextColor 
    call Clrscr   ; Clear the screen 
    call Crlf   ; New line 

    mov edx,OFFSET prompt 
    call WriteString 
    call ReadInt   ; Input integer into EAX 
    call Crlf   ; New line 

    lea esi, [fib+2] 
    mov cl, NUMBER_FIBS_TO_COMPUTE 
@@: 
    mov al, [esi-2] 
    add al, [esi-1] 
    mov [esi], al ;<------------This is where the error occurs 
    inc esi 
    loop @B 

; here print out the results or examine them with debugger 

E1: call Crlf   ; New line 
    call WaitMsg   ; "Press any key..." 
    mov eax,DefaultColor 
    call SetTextColor 
    call Clrscr 



exit 
main ENDP 
END main 

有没有办法,我缺少的规则。我已经完成了我的研究,但似乎无法找到符合我的情况的答案。

任何帮助将是伟大的! (另外请注意,我没有这样做,所以可能会有其他错误。)

谢谢!

+2

'fib'在哪里?还要注意'loop'使用'ecx'而不是'cl',所以你应该设置它的全部32位。 – Jester

+0

@Jester 'fib'在'.data'字段中初始化。 我在原文中添加了以上内容 – LAMBY

+0

当您的代码出错时,ESI有什么值? “fib”有多远? ECX里有什么,你为什么不读Jester评论的后半部分? –

回答

0

您的问题是,无论何处fib指向哪个加载到esi,该内存页被标记为只读。

通常,尝试写入GDT中标记为只读的内存位置会导致访问冲突。当您尝试从内存位置读取进程完全无法访问时,会发生分段错误。

正如@Jester指出的那样,您没有关注ECX中的高位位。当您在CL中设置循环控制值时,由于ECX未知,您的循环可能运行得远远超出您的预期。这会很快让你进入只读区域。

+0

数据部分没有正确定义“fib”? IDK MASM,但我认为这是读写。我认为代码只是运行WAY多次迭代而不是预期,因为像Jester最初指出的ECX中的垃圾很多,所以当指针增量到达一个未映射的页面时它会出错。 –

+0

这也可能是一个问题,但我无法看到他将其设置到任何有效内存区域的位置。 –

+0

嗯......再看一遍,我认为你是对的。杰斯特拥有它。 –