街机模拟游戏逆向工程(HACKROM)教程:[9]68K汇编move指令

本文主要是介绍街机模拟游戏逆向工程(HACKROM)教程:[9]68K汇编move指令,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在之前的文章中,我们已经多次测试过move这个指令,move指令可以说是68000汇编中最常用的一个指令,该指令可以把源操作数传递到所有寄存器以及所有的内存地址。而源操作数可以是所有寄存器的数据和所有的内存地址的值,同时源操作数也可以是一个立即数。我们来看看一个move指令可以操作的对象。

move.b  #$95, d0               *单字节立即数传递
move.w  #$40F5, d0             *双字节立即数传递
move.l  #$55667788, d0         *四字节立即数传递
move.w  d0, d1                 *[寄存器] 之间传递
move.w  d0, $0000104E          *[寄存器] 至 [内存] 之间传递
move.w  $00001062, d0          *[内存] 至 [寄存器] 之间传递
move.l  $00000800, $00000822   *[内存] 之间传递
move.w  (a0), (a1)             *[地址寄存器所指向内存] 之间传递
move.w  (a0), d0               *[地址寄存器所指向内存] 至 [数据寄存器] 之间传递
move.w  d1, (a0)+              *[数据寄存器] 至 [地址寄存器所指向内存] 之间传递,地址寄存器自增
move.w  d1, $10(a1)            *[数据寄存器] 至 [地址寄存器] + [偏移地址] 的内存之间传递
move.b  #$98, (a0)+            *[立即数] 至 [地址寄存器所指向内存] 之间传递
move.l  $29(a0), $00120020     *[地址寄存器] + [偏移地址] 至 [内存] 之间传递
move.b  $00120020, (a1)+       *[内存] 至 [地址寄存器] + [偏移地址] 之间传递

可以看到,move指令几乎可以在所有的存储空间中相互传递数据。而上面的部份指令,我们已经在之前的测试中尝试过了。这里我们要着重介绍的是带有偏移值地址的move指令,比如:


move.w  d1, $10(a1)            *[数据寄存器] 至 [地址寄存器] + [偏移地址] 的内存之间传递
move.l  $29(a0), $00120020     *[地址寄存器] + [偏移地址] 至 [内存] 之间传递

我们可以看到这两句指令中都有部份代码是带有偏移值的。如:$10(a1)的格式,这个我们在之前并没有见过,其实,带有偏移值的代码格式如:($10,a1) 和$10(a1)的格式都是正确,并且作用都是一模一样的。这两种风格的代码格式都是被认可的。

而这种带偏移格式的代码,也是在我们对游戏的逆向研究中最常见的一种格式。这种带偏移格式的代码我们需要结合[寄存器的值]+[偏移值]来计算出操作数据的地址。比如:

move.w  #$1234, $10(a1)

我们想要知道目标操作地的地址,我们需要先知道当前A1寄存器的值,这里我们假设A1=$100,那么目标操作地的地十就是$100+$10=$110。而使用偏移值来读写内存的好处我们可以用一段代码来说明:

    movea.l   #$325, a0move.b    #$01, (a0)move.b    #$02, $01(a0)move.b    #$03, $02(a0)move.b    #$04, $03(a0)move.b    #$05, $04(a0)move.b    #$06, $05(a0)move.b    #$07, $06(a0)

在这里,偏移值相当于一个索引值,我们在地址$325后面的地址,都可以通过这个索引值来读写所指向的内存。

我们在游戏中常常可以见到类似的情况,比如,在大部份街机游戏中玩家人物的所有内存值会保存在一段内存当中,这一段内存的长度在各个游戏中可能并不相同。我们可以把这段内存看成是一个对象(OBJ),在这个对象中,保存了玩家人物比如:血量,动作,位置,速度,人物ID,颜色,等所有数值。我们如果全部数值都用内存地址来读写,那么,因为街机游戏中基本上都有两个以上机位,那么,我们需要记住的内存地址就需要翻倍。那我们如果使用偏移值,就可以完美地解决这个问题了,我们来尝试一下:

我们设置一个索引:我们只列出部份玩家人物需要的数据

00.w    人物ID
02.w    人物血量
04.w    人物位置坐标
06.w    人物速度
08.w    人物颜色
0a.w    人物动作

然后,我们设置两个机位 的对象地址:

1P机位对象起始地址:100
2P机位对象起始地址:200

我们这时尝试读取1P机位的所有数据

    movea.l    #$100,a0move.w    (a0),d0        *读取人物IDmove.w    $02(a0),d1     *读取人物血量move.w    $04(a0),d2     *读取人物位置move.w    $06(a0),d3     *读取人物速度move.w    $08(a0),d4     *读取人物颜色move.w    $0a(a0),d5     *读取人物动作

当我们需要读取2P机位的数据时,只需要把a0的地址改为200,就可以方便地读取所有数据了。

在我们了解常用M68K的一些指令后,我们在对游戏的逆向研究中,会对此进行更加详细的说明。

这篇关于街机模拟游戏逆向工程(HACKROM)教程:[9]68K汇编move指令的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/619060

相关文章

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

Makefile简明使用教程

文章目录 规则makefile文件的基本语法:加在命令前的特殊符号:.PHONY伪目标: Makefilev1 直观写法v2 加上中间过程v3 伪目标v4 变量 make 选项-f-n-C Make 是一种流行的构建工具,常用于将源代码转换成可执行文件或者其他形式的输出文件(如库文件、文档等)。Make 可以自动化地执行编译、链接等一系列操作。 规则 makefile文件

SWAP作物生长模型安装教程、数据制备、敏感性分析、气候变化影响、R模型敏感性分析与贝叶斯优化、Fortran源代码分析、气候数据降尺度与变化影响分析

查看原文>>>全流程SWAP农业模型数据制备、敏感性分析及气候变化影响实践技术应用 SWAP模型是由荷兰瓦赫宁根大学开发的先进农作物模型,它综合考虑了土壤-水分-大气以及植被间的相互作用;是一种描述作物生长过程的一种机理性作物生长模型。它不但运用Richard方程,使其能够精确的模拟土壤中水分的运动,而且耦合了WOFOST作物模型使作物的生长描述更为科学。 本文让更多的科研人员和农业工作者

沁恒CH32在MounRiver Studio上环境配置以及使用详细教程

目录 1.  RISC-V简介 2.  CPU架构现状 3.  MounRiver Studio软件下载 4.  MounRiver Studio软件安装 5.  MounRiver Studio软件介绍 6.  创建工程 7.  编译代码 1.  RISC-V简介         RISC就是精简指令集计算机(Reduced Instruction SetCom

工作常用指令与快捷键

Git提交代码 git fetch  git add .  git commit -m “desc”  git pull  git push Git查看当前分支 git symbolic-ref --short -q HEAD Git创建新的分支并切换 git checkout -b XXXXXXXXXXXXXX git push origin XXXXXXXXXXXXXX

前端技术(七)——less 教程

一、less简介 1. less是什么? less是一种动态样式语言,属于css预处理器的范畴,它扩展了CSS语言,增加了变量、Mixin、函数等特性,使CSS 更易维护和扩展LESS 既可以在 客户端 上运行 ,也可以借助Node.js在服务端运行。 less的中文官网:https://lesscss.cn/ 2. less编译工具 koala 官网 http://koala-app.

【Shiro】Shiro 的学习教程(三)之 SpringBoot 集成 Shiro

目录 1、环境准备2、引入 Shiro3、实现认证、退出3.1、使用死数据实现3.2、引入数据库,添加注册功能后端代码前端代码 3.3、MD5、Salt 的认证流程 4.、实现授权4.1、基于角色授权4.2、基于资源授权 5、引入缓存5.1、EhCache 实现缓存5.2、集成 Redis 实现 Shiro 缓存 1、环境准备 新建一个 SpringBoot 工程,引入依赖:

Jenkins构建Maven聚合工程,指定构建子模块

一、设置单独编译构建子模块 配置: 1、Root POM指向父pom.xml 2、Goals and options指定构建模块的参数: mvn -pl project1/project1-son -am clean package 单独构建project1-son项目以及它所依赖的其它项目。 说明: mvn clean package -pl 父级模块名/子模块名 -am参数