假设我有这样的代码:
_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字节的填充添加到代码块中?
编辑:
情况发生了一些变化。
_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现在我该如何在这里添加正确的填充呢?
发布于 2022-10-26 13:54:35
好的,这是一个很难解释的问题,但我终于解决了我的问题。
最终起作用的代码如下:
.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指令一个标签。
考虑到所有这些因素,我们的结果如下:
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对齐请不要完全相信我的话。这只是许多测试的结果。如果你有问题,请随时评论。
否则,我希望这能帮助发现这个的人。
发布于 2022-10-25 22:14:05
或许可以使用org 510或org 510 + 7C00h来寻求这一点?
NASM的文档特别提到,NASM不支持MASM的org指令所允许的那种欺骗,这意味着MASM的org可用于此。NASM文档甚至是显示一个MASM示例
; 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。
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端口,例如,如果您没有使用bash或zsh这样的shell来扩展$((510/2)),那就是seek=255,因为dd将查找作为许多块,而不是字节。我不知道如何在Windows上传输任意的二进制数据;如果安装了python,也可以使用它,或者使用汇编程序创建一个2字节的文件。
dd.exe if=aa55.bin of=boot.bin conv=notrunc bs=2 count=1 seek=255https://stackoverflow.com/questions/74195910
复制相似问题