首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在MASM中跨段填充块?

如何在MASM中跨段填充块?
EN

Stack Overflow用户
提问于 2022-10-25 14:43:16
回答 2查看 93关注 0票数 2

假设我有这样的代码:

代码语言:javascript
复制
_TEXT16 SEGMENT USE16 'CODE'
_start:
    ; some code...
; add padding
byte 512-($-_start) dup (0)    ; works fine
_TEXT16 ENDS

_TEXT32 SEGMENT USE32 'CODE'
; some code
byte 1024-($-_start) dup (0)    ; error A2192: Operands must be in same segment
_TEXT32 ENDS

在NASM中,您只需执行类似于此times 1024-($-$$) db 0的操作,但不幸的是,MASM或JWASM中不支持$$,这正是我目前正在使用的。我需要这样做,使引导加载程序的块与可读磁盘扇区的大小一致。

因此,我的问题是,如何在MASM中将512字节的填充添加到代码块中?

编辑:

情况发生了一些变化。

代码语言:javascript
复制
_TEXT16 SEGMENT USE16 'CODE'
_start:
    ; some code...
_TEXT16 ENDS

_TEXT32 SEGMENT USE32 'CODE'
; some code
_TEXT32 ENDS

_TEXT64 SEGMENT USE64 'CODE'
; some code

; add padding
byte 510-($-_start) dup (0)    ; error A2192: Operands must be in same segment
dw 0AA55h
_TEXT64 ENDS

现在我该如何在这里添加正确的填充呢?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2022-10-26 13:54:35

好的,这是一个很难解释的问题,但我终于解决了我的问题。

最终起作用的代码如下:

代码语言:javascript
复制
.386P
.model TINY, C

_TEXT16 SEGMENT BYTE USE16 'CODE'
org 07C00h
begin16:

_start:
    xor ax, ax
    mov ds, ax
    mov es, ax
    mov ss, ax

    mov bp, 07C00h
    mov sp, bp

    mov ah, 0Eh
    mov al, 'A'
    mov bl, 0Fh
    int 10h

    cli
    hlt

end16:
size16 equ end16 - begin16
_TEXT16 ENDS

_TEXT32 SEGMENT BYTE USE32 'CODE'
begin32:

start_protected_mode:
    cli
    hlt

end32:
size32 equ end32 - begin32
_TEXT32 ENDS

.x64
_TEXT64 SEGMENT BYTE USE64 'CODE'
begin64:

start_long_mode:
    cli
    hlt

end64:
size64 equ end64 - begin64
_TEXT64 ENDS

_BOOTDATA SEGMENT BYTE 'DATA'
begin_data:

bootDisk db ?

end_data:
size_data equ end_data - begin_data
_BOOTDATA ENDS

_PADDING SEGMENT BYTE
org (510 - size16 - size32 - size64 - size_data)                ; either of these work
;byte (510 - size16 - size32 - size64 - size_data) dup(0)       ; either of these work
dw 0AA55h
_PADDING ENDS

END _start

这里发生的事情如下。第一个org指令(org 07C00h)设置程序的起始地址。它之所以这样做,只是因为我们通过使用END指令告诉它,我们已经为代码(END _start)的开头指定了一个标签。如果您不给END指令一个代码的声明标签,那么第一个org指令就会被解析为实际代码前面的许多零。或者简单地说,它实际上会用你给它的任何值来抵消你的代码。

然而,第二个org指令(org org (510 - size16 - size32 - size64 - size_data))的作用就像一个偏移量,即使您没有给END指令一个标签。

考虑到所有这些因素,我们的结果如下:

代码语言:javascript
复制
00000000  33C0              xor ax,ax
00000002  8ED8              mov ds,ax
00000004  8EC0              mov es,ax
00000006  8ED0              mov ss,ax
00000008  BD007C            mov bp,0x7c00
0000000B  8BE5              mov sp,bp
0000000D  B40E              mov ah,0xe
0000000F  B041              mov al,0x41
00000011  B30F              mov bl,0xf
00000013  CD10              int 0x10
00000015  FA                cli
00000016  F4                hlt
00000017  FA                cli
00000018  F4                hlt
00000019  FA                cli
0000001A  F4                hlt
0000001B  0000              add [bx+si],al
0000001D  0000              add [bx+si],al
0000001F  0000              add [bx+si],al
00000021  0000              add [bx+si],al
00000023  0000              add [bx+si],al
00000025  0000              add [bx+si],al
00000027  0000              add [bx+si],al
00000029  0000              add [bx+si],al
0000002B  0000              add [bx+si],al
0000002D  0000              add [bx+si],al
0000002F  0000              add [bx+si],al
00000031  0000              add [bx+si],al
00000033  0000              add [bx+si],al
00000035  0000              add [bx+si],al
00000037  0000              add [bx+si],al
00000039  0000              add [bx+si],al
0000003B  0000              add [bx+si],al
0000003D  0000              add [bx+si],al
0000003F  0000              add [bx+si],al
00000041  0000              add [bx+si],al
00000043  0000              add [bx+si],al
00000045  0000              add [bx+si],al
00000047  0000              add [bx+si],al
00000049  0000              add [bx+si],al
0000004B  0000              add [bx+si],al
0000004D  0000              add [bx+si],al
0000004F  0000              add [bx+si],al
00000051  0000              add [bx+si],al
00000053  0000              add [bx+si],al
00000055  0000              add [bx+si],al
00000057  0000              add [bx+si],al
00000059  0000              add [bx+si],al
0000005B  0000              add [bx+si],al
0000005D  0000              add [bx+si],al
0000005F  0000              add [bx+si],al
00000061  0000              add [bx+si],al
00000063  0000              add [bx+si],al
00000065  0000              add [bx+si],al
00000067  0000              add [bx+si],al
00000069  0000              add [bx+si],al
0000006B  0000              add [bx+si],al
0000006D  0000              add [bx+si],al
0000006F  0000              add [bx+si],al
00000071  0000              add [bx+si],al
00000073  0000              add [bx+si],al
00000075  0000              add [bx+si],al
00000077  0000              add [bx+si],al
00000079  0000              add [bx+si],al
0000007B  0000              add [bx+si],al
0000007D  0000              add [bx+si],al
0000007F  0000              add [bx+si],al
00000081  0000              add [bx+si],al
00000083  0000              add [bx+si],al
00000085  0000              add [bx+si],al
00000087  0000              add [bx+si],al
00000089  0000              add [bx+si],al
0000008B  0000              add [bx+si],al
0000008D  0000              add [bx+si],al
0000008F  0000              add [bx+si],al
00000091  0000              add [bx+si],al
00000093  0000              add [bx+si],al
00000095  0000              add [bx+si],al
00000097  0000              add [bx+si],al
00000099  0000              add [bx+si],al
0000009B  0000              add [bx+si],al
0000009D  0000              add [bx+si],al
0000009F  0000              add [bx+si],al
000000A1  0000              add [bx+si],al
000000A3  0000              add [bx+si],al
000000A5  0000              add [bx+si],al
000000A7  0000              add [bx+si],al
000000A9  0000              add [bx+si],al
000000AB  0000              add [bx+si],al
000000AD  0000              add [bx+si],al
000000AF  0000              add [bx+si],al
000000B1  0000              add [bx+si],al
000000B3  0000              add [bx+si],al
000000B5  0000              add [bx+si],al
000000B7  0000              add [bx+si],al
000000B9  0000              add [bx+si],al
000000BB  0000              add [bx+si],al
000000BD  0000              add [bx+si],al
000000BF  0000              add [bx+si],al
000000C1  0000              add [bx+si],al
000000C3  0000              add [bx+si],al
000000C5  0000              add [bx+si],al
000000C7  0000              add [bx+si],al
000000C9  0000              add [bx+si],al
000000CB  0000              add [bx+si],al
000000CD  0000              add [bx+si],al
000000CF  0000              add [bx+si],al
000000D1  0000              add [bx+si],al
000000D3  0000              add [bx+si],al
000000D5  0000              add [bx+si],al
000000D7  0000              add [bx+si],al
000000D9  0000              add [bx+si],al
000000DB  0000              add [bx+si],al
000000DD  0000              add [bx+si],al
000000DF  0000              add [bx+si],al
000000E1  0000              add [bx+si],al
000000E3  0000              add [bx+si],al
000000E5  0000              add [bx+si],al
000000E7  0000              add [bx+si],al
000000E9  0000              add [bx+si],al
000000EB  0000              add [bx+si],al
000000ED  0000              add [bx+si],al
000000EF  0000              add [bx+si],al
000000F1  0000              add [bx+si],al
000000F3  0000              add [bx+si],al
000000F5  0000              add [bx+si],al
000000F7  0000              add [bx+si],al
000000F9  0000              add [bx+si],al
000000FB  0000              add [bx+si],al
000000FD  0000              add [bx+si],al
000000FF  0000              add [bx+si],al
00000101  0000              add [bx+si],al
00000103  0000              add [bx+si],al
00000105  0000              add [bx+si],al
00000107  0000              add [bx+si],al
00000109  0000              add [bx+si],al
0000010B  0000              add [bx+si],al
0000010D  0000              add [bx+si],al
0000010F  0000              add [bx+si],al
00000111  0000              add [bx+si],al
00000113  0000              add [bx+si],al
00000115  0000              add [bx+si],al
00000117  0000              add [bx+si],al
00000119  0000              add [bx+si],al
0000011B  0000              add [bx+si],al
0000011D  0000              add [bx+si],al
0000011F  0000              add [bx+si],al
00000121  0000              add [bx+si],al
00000123  0000              add [bx+si],al
00000125  0000              add [bx+si],al
00000127  0000              add [bx+si],al
00000129  0000              add [bx+si],al
0000012B  0000              add [bx+si],al
0000012D  0000              add [bx+si],al
0000012F  0000              add [bx+si],al
00000131  0000              add [bx+si],al
00000133  0000              add [bx+si],al
00000135  0000              add [bx+si],al
00000137  0000              add [bx+si],al
00000139  0000              add [bx+si],al
0000013B  0000              add [bx+si],al
0000013D  0000              add [bx+si],al
0000013F  0000              add [bx+si],al
00000141  0000              add [bx+si],al
00000143  0000              add [bx+si],al
00000145  0000              add [bx+si],al
00000147  0000              add [bx+si],al
00000149  0000              add [bx+si],al
0000014B  0000              add [bx+si],al
0000014D  0000              add [bx+si],al
0000014F  0000              add [bx+si],al
00000151  0000              add [bx+si],al
00000153  0000              add [bx+si],al
00000155  0000              add [bx+si],al
00000157  0000              add [bx+si],al
00000159  0000              add [bx+si],al
0000015B  0000              add [bx+si],al
0000015D  0000              add [bx+si],al
0000015F  0000              add [bx+si],al
00000161  0000              add [bx+si],al
00000163  0000              add [bx+si],al
00000165  0000              add [bx+si],al
00000167  0000              add [bx+si],al
00000169  0000              add [bx+si],al
0000016B  0000              add [bx+si],al
0000016D  0000              add [bx+si],al
0000016F  0000              add [bx+si],al
00000171  0000              add [bx+si],al
00000173  0000              add [bx+si],al
00000175  0000              add [bx+si],al
00000177  0000              add [bx+si],al
00000179  0000              add [bx+si],al
0000017B  0000              add [bx+si],al
0000017D  0000              add [bx+si],al
0000017F  0000              add [bx+si],al
00000181  0000              add [bx+si],al
00000183  0000              add [bx+si],al
00000185  0000              add [bx+si],al
00000187  0000              add [bx+si],al
00000189  0000              add [bx+si],al
0000018B  0000              add [bx+si],al
0000018D  0000              add [bx+si],al
0000018F  0000              add [bx+si],al
00000191  0000              add [bx+si],al
00000193  0000              add [bx+si],al
00000195  0000              add [bx+si],al
00000197  0000              add [bx+si],al
00000199  0000              add [bx+si],al
0000019B  0000              add [bx+si],al
0000019D  0000              add [bx+si],al
0000019F  0000              add [bx+si],al
000001A1  0000              add [bx+si],al
000001A3  0000              add [bx+si],al
000001A5  0000              add [bx+si],al
000001A7  0000              add [bx+si],al
000001A9  0000              add [bx+si],al
000001AB  0000              add [bx+si],al
000001AD  0000              add [bx+si],al
000001AF  0000              add [bx+si],al
000001B1  0000              add [bx+si],al
000001B3  0000              add [bx+si],al
000001B5  0000              add [bx+si],al
000001B7  0000              add [bx+si],al
000001B9  0000              add [bx+si],al
000001BB  0000              add [bx+si],al
000001BD  0000              add [bx+si],al
000001BF  0000              add [bx+si],al
000001C1  0000              add [bx+si],al
000001C3  0000              add [bx+si],al
000001C5  0000              add [bx+si],al
000001C7  0000              add [bx+si],al
000001C9  0000              add [bx+si],al
000001CB  0000              add [bx+si],al
000001CD  0000              add [bx+si],al
000001CF  0000              add [bx+si],al
000001D1  0000              add [bx+si],al
000001D3  0000              add [bx+si],al
000001D5  0000              add [bx+si],al
000001D7  0000              add [bx+si],al
000001D9  0000              add [bx+si],al
000001DB  0000              add [bx+si],al
000001DD  0000              add [bx+si],al
000001DF  0000              add [bx+si],al
000001E1  0000              add [bx+si],al
000001E3  0000              add [bx+si],al
000001E5  0000              add [bx+si],al
000001E7  0000              add [bx+si],al
000001E9  0000              add [bx+si],al
000001EB  0000              add [bx+si],al
000001ED  0000              add [bx+si],al
000001EF  0000              add [bx+si],al
000001F1  0000              add [bx+si],al
000001F3  0000              add [bx+si],al
000001F5  0000              add [bx+si],al
000001F7  0000              add [bx+si],al
000001F9  0000              add [bx+si],al
000001FB  0000              add [bx+si],al
000001FD  0055AA            add [di-0x56],dl

正如您所看到的,我必须在每个段的开头和结尾使用标签来计算每个段的大小。然后,我为这些大小设置了一些常量。如果你扪心自问,为什么我不把一个标签放在代码的开头,另一个标签放在代码的末尾?然后我必须告诉你,你只能把标签放在段中,只能在同一段中访问它们。因此,常量,计算每一个的大小。

因此,结论是:

  • 第一个org设置程序偏移量,如果您在代码开始时给END一个标签
  • 所有下面的org指令都将起抵消作用,不管是什么
  • SEGMENTs与BYTEs对齐
  • 并做一些常量的标签计算,以获得正确的偏移量。

请不要完全相信我的话。这只是许多测试的结果。如果你有问题,请随时评论。

否则,我希望这能帮助发现这个的人。

票数 1
EN

Stack Overflow用户

发布于 2022-10-25 22:14:05

或许可以使用org 510org 510 + 7C00h来寻求这一点?

NASM的文档特别提到,NASM不支持MASM的org指令所允许的那种欺骗,这意味着MASM的org可用于此。NASM文档甚至是显示一个MASM示例

代码语言:javascript
复制
; MASM example from the NASM manual
        ORG 0 

        ; some boot sector code 

        ORG 510 
        DW 0xAA55

我不知道这会如何与多个片段交互。OP报告说,这只适用于同一段中的两个org指令。也许有一种方法可以指定一个段的起源作为声明它的一部分?

或者另一种选择,您可以要求MASM计算那些早期段的大小,如果没有将它们填充到固定大小的情况下呢?(当大小固定时,事情显然很简单:您只需使第二段512字节,在第一个512字节段之后,所以它将以1024结束。)

比如byte 510 - sizeof _TEXT16 -($-_start) dup (0)之类的东西,也可以减去前几段的长度吗?我不知道MASM是否允许这样做。显然,这是行不通的,因此可能定义了一个或,或者在前面两个片段中的每个片段中都定义了什么。

不管是哪种方式,如果有任何可以对齐它们的起始点的话,这都不会考虑到段之间的填充。

当然,如果您不知道如何让汇编程序为您做这件事,也可以将引导签名单独附加到汇编程序的平面二进制输出中,作为构建过程的一部分。

在Linux shell中,此命令打开boot.bin,查找字节510,并写入db 0x55, 0xaa

代码语言:javascript
复制
echo -ne '\x55\xAA' | dd of=boot.bin conv=notrunc bs=2 count=1 seek=$((510/2))

如果您无法使用dd,就会有http://www.chrysocome.net/downloads/dd-0.6beta3.src.zip端口,例如,如果您没有使用bashzsh这样的shell来扩展$((510/2)),那就是seek=255,因为dd将查找作为许多块,而不是字节。我不知道如何在Windows上传输任意的二进制数据;如果安装了python,也可以使用它,或者使用汇编程序创建一个2字节的文件。

代码语言:javascript
复制
dd.exe if=aa55.bin of=boot.bin conv=notrunc bs=2 count=1 seek=255
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/74195910

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档