6

根据维基百科,N64 只有 4 MB 的 RDRAM(扩展包为 8 MB),其他数量也同样小(4 KB 左右的 L1 缓存)。但是,我在 Google 上找到的技术文档指出,它的内存地址范围从 $0000:0000 到 $FFFF:FFFF——即 4 GB!由于现有的 N64 模拟器(如 Project64)不会占用 4 GB 的 RAM,那么模拟内存映射如何工作?我尝试过查看各种文件等,所有这些文件似乎都至少略有不同。有人对这个问题有什么建议吗?

具体来说,这是我找到的内存映射:

0x0000 0000 to 0x03EF FFFF RDRAM Memory
0x03F0 0000 to 0x03FF FFFF RDRAM Registers
0x0400 0000 to 0x040F FFFF SP Registers
0x0410 0000 to 0x041F FFFF DP Command Registers
0x0420 0000 to 0x042F FFFF DP Span Registers
0x0430 0000 to 0x043F FFFF MIPS Interface (MI) Registers
0x0440 0000 to 0x044F FFFF Video Interface (VI) Registers
0x0450 0000 to 0x045F FFFF Audio Interface (AI) Registers
0x0460 0000 to 0x046F FFFF Peripheral Interface (PI) Registers
0x0470 0000 to 0x047F FFFF RDRAM Interface (RI) Registers
0x0480 0000 to 0x048F FFFF Serial Interface (SI) Registers
0x0490 0000 to 0x04FF FFFF Unused
0x0500 0000 to 0x05FF FFFF Cartridge Domain 2 Address 1
0x0600 0000 to 0x07FF FFFF Cartridge Domain 1 Address 1
0x0800 0000 to 0x0FFF FFFF Cartridge Domain 2 Address 2
0x1000 0000 to 0x1FBF FFFF Cartridge Domain 1 Address 2
0x1FC0 0000 to 0x1FC0 07BF PIF Boot ROM
0x1FC0 07C0 to 0x1FC0 07FF PIF RAM
0x1FC0 0800 to 0x1FCF FFFF Reserved
0x1FD0 0000 to 0x7FFF FFFF Cartridge Domain 1 Address 3
0x8000 0000 to 0xFFFF FFFF External SysAD Device
4

3 回答 3

2

您拥有的映射是抽象的,如果您查看更详细的内存映射,您会发现未映射的内存有很大的差距。不包括映射的外部盒式ROM(等),将可用内存的各个部分相加。您最终将分配超过 4MB 的空间,包括 RDRAM。还要注意,超过 0x80000000 的地址实际上是低地址的镜像,区别在于有些是直接映射的(物理内存),有些是 TLB 映射的(虚拟内存)。

0x00000000 - 0x7fffffff  KUSEG  TLB mapping
0x80000000 - 0x9fffffff  KSEG0  Direct map, cache
0xa0000000 - 0xbfffffff  KSEG1  Direct map, non-cache
0xc0000000 - 0xdfffffff  KSSEG  TLB mapping
0xe0000000 - 0xffffffff  KSEG3  TLB mapping

另请注意,磁带内存映射到 0xb0000000。这没有在内存映射中明确显示。

于 2011-08-11T17:28:20.010 回答
1

无论您要模拟多少内存,您都不需要主机上有那么多可用内存(您不需要 4 GB,甚至不需要 4 MB)。相反,使用可以通过地址值访问模拟内存的数据结构。仅当您需要在模拟内存中存储某些内容时,才在真实内存中分配空间。

但是,实际分配上述内存量可能是微不足道的。

像 Simon 一样,我也会首先假设段:偏移理论,但您上面列出的地址范围似乎与该理论完全矛盾。此外,整个“64”位地址空间的东西。

请注意,大部分地址空间分配给外部接口(盒等),而不是内部硬件资源。

于 2009-12-03T05:03:45.557 回答
0

AFAIK 系统的处理器最多可以有 4 GB 没有任何问题,但 n64 本身没有使用此功能。所以我认为如果处理器从该区域请求数据,它只会返回 00。

于 2017-02-14T14:02:39.027 回答