[貌似已解决]gcc编译汇编和c的函数调用的问题

发布于 2022-09-23 15:22:15 字数 4094 浏览 19 评论 0

感谢大家热情的回复,我后来自己好好想了想,然后翻了翻资料,和同学讨论了下,貌似找到了问题的根源。
main.o的.text被ld贴到了512字节后面,但bios只会将第一个扇区读入内存,所以后面的压根就没有读入,自然一call就挂了。
不知道,我这样理解有没有错。

本来是想在写bootsector的时候就用C,看来还是不能偷懒阿,只有在loader再开始了。

我写了一个引导扇区的程序,想在其中调用用c写的函数,但是发现,一旦在汇编中调用了C的函数之后,系统就卡在那里不往下执行了,请问这怎么解决阿。
我是新手,还望大家多多帮忙阿。
boot.S:

#define MSG(x) leaw x,%si;call display

.code16
.section .text
.globl _start
_start:
    movw $0x2000,%sp
    movw %sp,%bp

    #set video mode
    movw $0x0003,%ax
    int $0x10
    
    MSG(sector_msg1)
    call main
    MSG(sector_msg2)
    
    
    _endless_loop:jmp _endless_loop

sector_msg1:
    .asciz "bootsector: looking for a loader... "
sector_msg2:
    .asciz "found\n\r"

.globl test
test:
    MSG(sector_msg2)
    ret

display:
    cld
    movb $0xe,%ah    /* use BIOS interrupt 10,e */
    movb $0xf,%bl    /* font color */
    display_start:
    lodsb
    orb %al,%al
    jz display_end
    int $0x10
    jmp display_start
    display_end:
    ret

.org 510
.word 0xaa55

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(9

梦在深巷 2022-09-30 15:22:15

好想没看到指定SP 是不这问题

泪眸﹌ 2022-09-30 15:22:15

原帖由 lixinwei1985@si 于 2009-2-17 14:01 发表
好想没看到指定SP 是不这问题

加上了这个
movw $0x2000,%sp
movw %sp,%bp
还是这个样子

鸠书 2022-09-30 15:22:15

这可能是常识的问题,是你没有注意,一个程序应该只有一个main函数!你这里C函数是用main!

荒路情人 2022-09-30 15:22:15

原帖由 破碎细胞 于 2009-2-17 13:23 发表
我写了一个引导扇区的程序,想在其中调用用c写的函数,但是发现,一旦在汇编中调用了C的函数之后,系统就卡在那里不往下执行了,请问这怎么解决阿。
我是新手,还望大家多多帮忙阿。
boot.S:
#define MSG(x) ...

没看你的代码,因为你的概念就是错的。
当你执行“引导扇区的程序”时,内存里就只有ROM-BIOS和这个引导记录代码,C库函数代码还没有进来,你没法调用。

冷情 2022-09-30 15:22:15

貌似不是这个问题,改成cmain结果是一样的。

梦晓ヶ微光ヅ倾城 2022-09-30 15:22:15

你用你的MSG宏插到main函数里去跟踪看看

月光色 2022-09-30 15:22:15

原帖由 beepbug 于 2009-2-17 18:43 发表

没看你的代码,因为你的概念就是错的。
当你执行“引导扇区的程序”时,内存里就只有ROM-BIOS和这个引导记录代码,C库函数代码还没有进来,你没法调用。

并没有调用C的库函数。
我的目的仅仅是想用C来写一部分代码,这样轻松一点。
还是看了代码再说比较好一点。

靑春怀旧 2022-09-30 15:22:15

原帖由 cjaizss 于 2009-2-19 10:02 发表
你用你的MSG宏插到main函数里去跟踪看看

我貌似大概知道什么问题了。
C的.text被贴到了512字节后面,而bios开始只读取引导扇区,也就是512个字节,后面的压根就读如内存,所以一call就挂了。不知道这样解释有没有道理。
其实,我的初衷是想在bootsector开始就用c来写部分代码,现在看来只有在loader开始了。

百思不得你姐 2022-09-30 15:22:15

Mark 一下,哈哈。不能偷懒哦。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文