linux nasm汇编中调用printf不报错,但调用scanf报错。抛出了分段错误(核心转储)

当我写了如下汇编时

; nasm -f elf64 -g -F dwarf charsin.asm
; gcc charsin.o -no-pie -o charsin
; ld -o eatclib eatclib.o
; gdb eatclib[SECTION .data]SPrompt db 'Enter string data, followed by Enter: ',0IPrompt db 'Enter an integer value, followed by Enter: ',10,0IFormat db "%d",0SShow db 'The string you entered was: %s',0IShow db 'The Integer value you entered was: %5d',10,0[SECTION .bss]IntVal resd 1InString resb 128 [SECTION .text]extern stdinextern fgetsextern printfextern scanfglobal mainmain:push rbpmov rbp,rsppush rbxpush rsipush rdi;push SPromptmov rdi,SPrompt ; 传递参数mov rax,0call printf;add rsp,8; rdi,rsi,rdx,rcx分别保存第1,2,3,4个参数;push qword [stdin];push 72;push InStringmov rdi,InStringmov rsi,72mov rdx,[stdin]mov rax,0call fgets;add rsp,24;push InString;push SShowmov rdi,SShowmov rsi,InString;在汇编代码中,若是调用变长参数的函数,需要使用al这个寄存器记录使用到的向量寄存器数量。;这段代码中eax中存放的不是系统调用号,存放的是向量寄存器使用到的数量0,因为printf使用的是变长参数。mov rax,0call printf;add rsp,16mov rax,0push IPromptmov rdi,IPrompt ; 传递参数call printfadd rsp,8;push IntVal;push IFormatmov rdi,IFormat mov rsi,IntVal ; 保留数字的内存地址xor rax,raxcall scanf;add rsp,16;mov rax, 0  ;sys_read 系统调用号;mov rdi, 0  ; 文件描述符 标准输入;mov rsi,IntVal ; 保留数字的内存地址;mov rdx, 4;syscallxor rsi,rsimov rax,0mov rdi,IShow ; 传递格式参数mov esi,[IntVal]call printf;add rsp,16pop rdipop rsipop rbxmov rsp,rbppop rbpret

编译后,系统会如下段错误(Segmentation fault (core dumped)).
在这里插入图片描述

在函数的开始/结束处使用 sub rsp, 8/add rsp, 8 将堆栈重新对齐到 16函数执行调用之前的字节。

; nasm -f elf64 -g -F dwarf charsin.asm
; gcc charsin.o -no-pie -o charsin
; ld -o eatclib eatclib.o
; gdb eatclib[SECTION .data]SPrompt db 'Enter string data, followed by Enter: ',0IPrompt db 'Enter an integer value, followed by Enter: ',10,0IFormat db "%d",0SShow db 'The string you entered was: %s',0IShow db 'The Integer value you entered was: %5d',10,0[SECTION .bss]IntVal resd 1InString resb 128 [SECTION .text]extern stdinextern fgetsextern printfextern scanfglobal mainmain:push rbpmov rbp,rsppush rbxpush rsipush rdi;在函数的开始/结束处使用 sub rsp, 8/add rsp, 8 将堆栈重新对齐到 16函数执行调用之前的字节。sub rsp, 8;push SPromptmov rdi,SPrompt ; 传递参数mov rax,0call printf;add rsp,8; rdi,rsi,rdx,rcx分别保存第1,2,3,4个参数;push qword [stdin];push 72;push InStringmov rdi,InStringmov rsi,72mov rdx,[stdin]mov rax,0call fgets;add rsp,24;push InString;push SShowmov rdi,SShowmov rsi,InString;在汇编代码中,若是调用变长参数的函数,需要使用al这个寄存器记录使用到的向量寄存器数量。;这段代码中eax中存放的不是系统调用号,存放的是向量寄存器使用到的数量0,因为printf使用的是变长参数。mov rax,0call printf;add rsp,16mov rax,0push IPromptmov rdi,IPrompt ; 传递参数call printfadd rsp,8;push IntVal;push IFormatmov rdi,IFormat mov rsi,IntVal ; 保留数字的内存地址xor rax,raxcall scanf;add rsp,16;mov rax, 0  ;sys_read 系统调用号;mov rdi, 0  ; 文件描述符 标准输入;mov rsi,IntVal ; 保留数字的内存地址;mov rdx, 4;syscallxor rsi,rsimov rax,0mov rdi,IShow ; 传递格式参数mov esi,[IntVal]call printf;add rsp,16;在函数的开始/结束处使用 sub rsp, 8/add rsp, 8 将堆栈重新对齐到 16函数执行调用之前的字节。add rsp, 8pop rdipop rsipop rbxmov rsp,rbppop rbpret

编译后,程序运行正常。
在这里插入图片描述

参考段错误
StackOverflow

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/501050.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

人工智能应用工程师职业技能提升如何考取,需要具备怎样的技能?

人工智能应用工程师是能够利用人工智能相关技术进行应用研发,并开展各类工作的从业人员统称。 人工智能应用工程师考试是对人工智能领域从业者的全面认证,共分为初级、中级、高级三个等级,分别对应了人工智能应用工程师未来发展的三个大致方向…

本地写的Bash脚本,Linux端运行报错:/bin/bash^M: bad interpreter: No such file or directory

背景 在本地写了个Bash Shell脚本,但上传到Linux端后加完权限执行时报错: (脚本名:script.sh) -bash: ./script.sh: /bin/bash^M: bad interpreter: No such file or directory 分析 这个错误通常是由于脚本文件的行…

SSL证书快过期了怎么办?

SSL(Secure Sockets Layer)证书是保障网站安全、确保用户数据加密传输的关键元素。当SSL证书接近其有效期限时,及时更换新证书至关重要,以免影响网站的安全性和用户体验。下面是一份详尽的指南,指导您分步有序地完成SS…

【笔记】:更方便的将一个List中的数据传入另一个List中,避免多重循环

这里是 simpleInfoList 集合&#xff0c;记为集合A&#xff08;传值对象&#xff09; List<CourseSimpleInfoDTO> simpleInfoList courseClient.getSimpleInfoList(courseIds);if(simpleInfoListnull){throw new BizIllegalException("当前课程不存在!");}这…

LeetCode 2581.统计可能的树根数目:换根DP(树形DP)

【LetMeFly】2581.统计可能的树根数目&#xff1a;换根DP(树形DP) 力扣题目链接&#xff1a;https://leetcode.cn/problems/count-number-of-possible-root-nodes/ Alice 有一棵 n 个节点的树&#xff0c;节点编号为 0 到 n - 1 。树用一个长度为 n - 1 的二维整数数组 edges…

能让薪资翻3倍的软件测试面试经验

前言 面试真题&#xff1a;3 轮技术面 HR 面 面试总共经历四轮的面试&#xff0c;三轮的技术面试和一轮的 HR 面试&#xff0c;共耗时 5 个小时以上。 一面&#xff08;组长面&#xff09; 上家公司项目以及团队的规模是怎么样的&#xff1f; 你负责的项目整体的流程是怎么样的…

基于ssm课程管理系统

基于SSM的课程管理系统的设计与实现 摘 要 当下&#xff0c;正处于信息化的时代&#xff0c;许多行业顺应时代的变化&#xff0c;结合使用计算机技术向数字化、信息化建设迈进。以前学校对于课程信息的管理和控制&#xff0c;采用人工登记的方式保存相关数据&#xff0c;这种以…

【bash】2、手把手实现一个 bash shell:多个机器批量执行 shell 命令,支持 ip 补全

文章目录 一、需求&#xff1a;多台机器批量远程执行 shell 命令1.1 业务需求拆解为脚本需求1.2 帮助函数&#xff1a;使用说明文档1.3 main 函数框架 二、功能&#xff1a;单机 sshp 执行2.1 fullip 函数&#xff1a;实现 ip 补全2.1.1 参数说明2.1.2 定义全局变量2.1.3 实现&…

Doccano 修复 spacy.gold 的bug

引言 最初只是想把Doccano标注的数据集转换成BIO(类似conll2003数据集)的标注格式&#xff1b; 摘要 可先阅读一下教程&#xff1a;【已解决】关于如何将Doccano标注的文本转换成NER模型可以直接处理的CoNLL 2003格式 装包:pip install doccano-transformer 报错信息 运行…

基于springboot+vue的中药实验管理系统(前后端分离)

博主主页&#xff1a;猫头鹰源码 博主简介&#xff1a;Java领域优质创作者、CSDN博客专家、阿里云专家博主、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战&#xff0c;欢迎高校老师\讲师\同行交流合作 ​主要内容&#xff1a;毕业设计(Javaweb项目|小程序|Pyt…

SpringBoot源码解读与原理分析(三十八)SpringBoot整合WebFlux(一)WebFlux的自动装配

文章目录 前言第13章 SpringBoot整合WebFlux13.1 响应式编程与Reactor13.1.1 命令式与响应式13.1.2 异步非阻塞13.1.3 观察者模式13.1.4 响应性13.1.5 响应式流13.1.6 背压13.1.7 Reactor13.1.7.1 Publisher13.1.7.2 Subscriber13.1.7.3 Subscription13.1.7.4 Processor13.1.7.…

【机器学习实战1】泰坦尼克号:灾难中的机器学习(一)数据预处理

&#x1f338;博主主页&#xff1a;釉色清风&#x1f338;文章专栏&#xff1a;机器学习实战&#x1f338;今日语录&#xff1a;不要一直责怪过去的自己&#xff0c;她曾经站在雾里也很迷茫。 &#x1f33c;实战项目简介 本次项目是kaggle上的一个入门比赛 &#xff1a;Titani…