linux - NASM Linux 中的 strlen

标签 linux assembly x86 nasm

再次打扰一下。我正在尝试理解学习汇编语言。但是我有很多问题。我正在尝试使用 NASM 中的字符串。我已将字符串常量复制到字符串变量。最大大小为 50。所以我想验证这个界限。但是这个程序抛出一个段错误。我在 MASM 中使用了一个示例,因此可能存在 NASM 语法的使用错误。 我的程序如下:

section .data                                                                                                                    
   MAXTEXTSIZE equ 50
   _cte_hola db "Hola", 0
   _cte_mundo db "Mundo", 0

section .bss
   MAIN_d resb MAXTEXTSIZE+1

section .text
      global _start

strlen:
  mov bx, 0
  strl01:
  cmp WORD [SI+BX],0 t
  je strend 
  inc bx 
  jmp strl01
strend:
  ret

strcpy:
   call strlen 
   cmp bx, MAXTEXTSIZE 
   jle copiarsizeok    
   mov bx, MAXTEXTSIZE
copiarsizeok:mov cx, bx
   cld 
   rep movsb 
   mov al,0 
   mov BYTE [DI], al
   ret


_start:
  mov ds, ax
  mov es, ax
  mov si, [MAIN_d]
  mov di, [_cte_hola]
  call strcpy
  mov eax, 1
  mov ebx, 0
  int 80h  

在此先感谢并打扰一下。我的问题对于汇编程序员来说很愚蠢。

最佳答案

我相信您正在尝试在 Linux 中制作 32 位程序,但您的示例是 16 位的。

  1. 在 Linux 中,所有指针都是 32 位的。因此,请使用扩展寄存器:esi、edi、ebx 等。您仍然可以将 8 位和 16 位寄存器用于算术和数据处理,但不能用作内存指针。

  2. 在 strlen 中,您必须比较 byte [esi+ebx], 0 而不是 word。

  3. 不要在 Linux 中设置段寄存器。它们将由操作系统设置,您无法触摸它们。在 Linux 中,所有内存都是一个平面区域,您不必再使用段寄存器。

关于linux - NASM Linux 中的 strlen,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19797609/

相关文章:

汇编代码帮助(创建新文件)

linux - 系统调用导致Segmentation Fault

c - DMA 传输 RAM 到 RAM

c++ - 在使用不同于目标发行版的编译器进行构建时,处理库依赖关系的常用方法是什么?

c - 信号中断 read()

linux - 通过 bash 脚本为 Linux 服务器设置代理失败

c - 未处理的异常 0xC0000008 : An invalid handle was specified in dynamic recompiler

windows - FASM 汇编程序在退出前等待

assembly - 如何编译汇编代码?

python - 以另一个用户身份运行 python 脚本