5

我似乎正在与我的愚蠢作斗争。

该站点解释了各种版本的 CP/M 下的系统调用。

但是,当我尝试使用调用 2(C_WRITE,控制台输出)时,什么都没有发生。

我有以下代码。

ORG 100h
LD E,'a'
LD C,2
CALL 5
CALL 0

我在这里背诵这句话。如果有错别字,请放心,它们不在原始文件中,因为文件确实编译了,而且我有一个 COM 文件要启动。

我认为这些线条的含义如下:

  1. 确保它被加载到地址 100h(0h 到 FFh 是零页)。
  2. 将 ASCII 'a' 加载到系统调用 2 的 E 寄存器中。
  3. 将整数 2 加载到系统调用 2 的 C 寄存器中。
  4. 进行系统调用(系统调用的 JMP 位于零页中的地址 5)。
  5. 结束程序(退出命令在零页的地址 0 处)。

程序启动和退出没有问题。如果我删除最后一个命令,它会挂起计算机(我猜这也是预期的,并显示 CALL 0 有效)。

但是,它不打印 ASCII 字符。(但它确实打印了一个额外的新行,但系统可能已经这样做了。)

如何让我的 CP/M 程序执行系统调用应该执行的操作?我究竟做错了什么?

更新:问题是我尝试过的所有汇编程序都需要某种格式的源文件。此文件与 Microsoft 的宏汇编器一起使用:

        .Z80
START:  LD      E,'a'
        LD      C,2
        CALL    5
        JP      0

认为(我猜)asm.com(DR 的汇编程序)和 m80.com(微软的宏汇编程序)期待 Intel 8080 助记符,并且必须告知他们何时必须期待 z80 助记符,这显然是不同的。

无论如何我都会接受下面的答案,因为它也是正确的,因为它建议只需编写图像本身而不用担心 asm.com。

4

1 回答 1

3

明显的可能性:您的汇编程序是否将 'a' 视为十六进制而不是 ASCII 字符?0xa是换行的 ASCII。也许尝试'g'或检查你的汇编输出的十六进制转储?

除此之外,您的代码看起来不错,尽管RST 0会节省一些字节。

编辑:

我将您的代码手动组装到:

1e 61
0e 02 
cd 05 00
cd 00 00

我将它作为 mytest.com 保存到磁盘。然后我启动了这个 CP/M 仿真器(警告:这是一个直接的文件下载链接;仿真器的标题似乎是Joan Riff 的“Z80MU PROFESSIONAL”Z80 和 CP/M 2.2 仿真器,它本身已有 20 多年的历史,所以似乎没有有一个网页)在 DOSBox 中运行 DOS 并运行 mytest.com。它输出字母'a'。因此,无论是您的工具链还是您的 CP/M 都有问题。

一张照片,因为它确实发生了:

在此处输入图像描述

于 2012-09-03T23:02:59.130 回答