NES基本原理(六)手柄

简介: 手柄

首发公众号:Rand_cs

Controller&Format

Controller

本文讲述 NES 的输入设备,最为常见的就是手柄 joypad:

一般支持两个手柄,手柄 1 和手柄 2 分别映射到 CPU 的地址空间 0x4016 和 0x4017,我们可以从这两个寄存器读出手柄按键的状态,1 代表按下,0 表示弹起状态。

手柄的内部有个移位寄存器来存放这些键的状态,每次从 0x4016 读取的数据只表示一个键的状态,需要连续读取 8 次才能读取所有键的状态,8 个键的读取顺序如下所示:

$$A \rightarrow B \rightarrow Seclect \rightarrow Start \rightarrow Up \rightarrow Down \rightarrow Left \rightarrow Right$$

读取 Right 后,如果继续读会一直返回 1。

手柄内部有个 strobe,可以通过写 0x4016 来设置这个 strobe,如果设为 1,手柄会不停的将当前键的状态装载到移位寄存器,此模式下,CPU 读取键位状态会一直获取键 A 的状态。如果 strobe 设为 0,会停止装载键的状态,这个模式下连续读取 8 次就是我们想要的 8 个键的状态。

看个代码好理解些:

  LDA #$01      ; strobe 设为1,装载键的状态 
  STA $4016
  LDA #$00      ; strobe 设为0,停止装载
  STA $4016     ; tell both the controllers to latch buttons

  LDA $4016     ; player 1 - A
  LDA $4016     ; player 1 - B
  LDA $4016     ; player 1 - Select
  LDA $4016     ; player 1 - Start
  LDA $4016     ; player 1 - Up
  LDA $4016     ; player 1 - Down
  LDA $4016     ; player 1 - Left
  LDA $4016     ; player 1 - Right

  LDA $4017     ; player 2 - A
  LDA $4017     ; player 2 - B
  LDA $4017     ; player 2 - Select
  LDA $4017     ; player 2 - Start
  LDA $4017     ; player 2 - Up
  LDA $4017     ; player 2 - Down
  LDA $4017     ; player 2 - Left
  LDA $4017     ; player 2 - Right

NES 手柄的工作原理就是这样,很简单,不够写一篇哪,下面就说说 NES 文件格式:

Format

NES 文件最初是 Marat Fayzullin 为了他的 NES 模拟器而定义的一种文件格式,之后就一直沿用,只是有了些更新,来看看 NES 文件是怎样的:

iNES header

byte0-2,魔数字符串 “NES”,很多文件格式的开头都有这么一个标识,比如说 elf 文件,这里也一样的道理。

byte3,包含了值 0x1A,也是标识魔数的一部分

byte4,16KB 的 PRG 的数量

byte5,8KB 的 CHR 的数量

byte6,Rom control byte 1:

  • bit0:0-水平镜像,1-垂直镜像
  • bit1:是否有 RAM 映射到 0x6000-0x7FFF,这部分可用作存档
  • bit2:是否存在 512 字节的 trainer,trainer 用于一些被修改过的游戏使其运行在不同的硬件上,比如说早期的一些 RAM 卡带,这里就要放置一些额外的兼容性代码,一般没有 trainer。
  • bit3:此位置 1 会覆写 bit0,表示 four-screen mirroring
  • bit4-7:mapper number byte 低 4 位,表示使用的哪种 mapper

byte7,ROM control byte 2:

  • bit0-3,保留,全 0
  • bit4-7,mapper number byte 高 4 位

byte8,8KB 的 RAM banks 的数量,主要是为了兼容前代的 ines 文件格式

byte9-15,保留,全 0

后面就是文件主题,如果有 trainer,那紧接着 header 的就是trainer,否则就是 PGR 和 CHR 紧跟其后。

NES 的文件格式就是这样,来看超级马里奥的例子,同样的直接使用 FCEUX 打开超级马里奥,截图如下所示:

然后再直接查看二进制文件:

byte0-3:0x4e, 0x45, 0x53, 0x1a 为 NES+0x1a

byte4:0x02,表示 16KB 的 PRG 有 2 个,说明 PRG 有 32KB

byte5:0x01,表示 8KB 的 CHR 有 1 个,说明 CHR 有 8KB

byte6-7:0x01,0x00,表示垂直镜像,mapper number 为 0

上述就是超级马里奥文件头的基本信息,可以与从 FCEUX 截的图做对比,发现是吻合的没问题。

好了本文就到这里,有什么问题还请批评指正。
首发公众号:Rand_cs

目录
相关文章
|
5月前
|
前端开发 算法
深度研究Agent架构解析:4种Agent架构介绍及实用Prompt模板
本文系统梳理了深度搜索Agent的主流架构演进:从基础的Planner-Only,到引入评估反馈的双模块设计,再到支持层次化分解的递归式ROMA方案。重点解析了问题拆解与终止判断两大核心挑战,并提供了实用的Prompt模板与优化策略,为构建高效搜索Agent提供清晰路径。
2151 10
深度研究Agent架构解析:4种Agent架构介绍及实用Prompt模板
|
3月前
|
存储 数据采集 机器学习/深度学习
大模型应用:大模型越大越好?模型参数量与效果的边际效益分析.51
本文揭示大模型“参数量越大效果越好”的误区,详解边际效益递减规律:小模型(1B→7B)提升显著,中等模型(7B→13B)仍具性价比,而超大模型(70B→175B)效果几无增长却大幅增加算力与存储成本。通过控制变量、量化指标与曲线分析,指导读者科学选型——找到效果与成本平衡的最优参数阈值。
870 14
|
人工智能 自然语言处理 测试技术
UGMathBench:评估语言模型数学推理能力的动态基准测试数据集
近年来,人工智能蓬勃发展,自然语言模型(LLM)进展显著。语言模型被广泛应用于自动翻译、智能客服、甚至医疗、金融、天气等领域。而研究者们仍在不断努力,致力于提高语言模型的规模和性能。随着语言模型的蓬勃发展,评估一个语言模型的性能变得越来越重要。其中一个重要的评估指标,就是衡量语言模型的推理能力和解决数学问题的能力。
559 38
|
存储 索引
|
Java 应用服务中间件 网络性能优化
Java 生成证书:使用 OpenSSL
Java 生成证书:使用 OpenSSL
|
存储 缓存 芯片
|
机器学习/深度学习 人工智能 搜索推荐
AI技术在情感识别方面有哪些具体应用
AI在元宇宙学习中扮演关键角色,通过数据收集分析用户习惯、兴趣,提供个性化推荐。情感识别调整教学策略,智能评估反馈学习效果,实时互动解答问题,自适应学习系统匹配个体需求。同时,注重隐私安全保护,打造高效、精准、个性化的学习环境。
|
芯片 数据格式 索引