街机模拟游戏逆向工程(HACKROM)教程:[0]工具

2024-01-15 01:36

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

街机hack,从早期的街霸-降龙版

 到后期对各种街机的各种改动版本

这些成果,就是对街机游戏的代码进行逆向分析的结果。对于大部份街机游戏,是基于摩托罗拉68000的CPU,使用的是一套特别的汇编指令集。

一、MAME下载

我们想要对游戏进行逆向分析,首先我们需要的是一个可以查看游戏中的汇编代码的工具,这里选择也只能选择的是一款比较流行的多机种模拟器工具,MAME。

下载地址:MAME | Latest MAME Release

在撰写该篇文章时,MAME所对应的最高版本为0.261。

二、MAME安装

该文件本身为一个EXE文件,但其实为一个自解压的压缩包,我们可以选择直接运行安装,也可以选择用压缩工具来把里面的文件解压出来。

artword        - 布局管理文件

bgfx             - BGFX着色器、着色器链和效果的定义

ctrlr              - 键盘按钮映射

docs            - 使用说明文档

hash            - 所有可模拟的游戏或软件列表

hlsl              - 滤镜文件

ini                - 配置文件

language     - 语言文件

plugins        - 插件文件

roms            - ROM文件

samples      - 一些声音样本文件

 三、MAME运行

其主要运行文件为mame.exe,直接双击可以运行MAME:

和mameplus不同,官方的mame没有窗口化的界面。

此时,我们还没有任何ROM文件,所以无法运行任何游戏。要运行需要的游戏,我们还需要要下载对应的ROM文件,我们去MAME官网下载一些网友原创非商业用途的游戏来进行测试。

下载地址:MAME | ROMs for Free Download

我们选择一个叫carpolo的小游戏来测试

MAME | Car Polo (Exidy, 1977)

下载该ROM文件,放到roms文件夹中。

我们可以用多种方法来运行该游戏:

1、双击"mame.exe"运行MAME,在搜索框中输入"carpolo":

 双击"Car Polo"运行该游戏。

2、在mame.exe相同的文件夹中,新建一个文本文档,重命名为carpolo.bat批处理文件

选中该批处理文件,右键,选择编辑或用文本编辑工具打开该文件,在文件中输入批处理命令:

mame.exe carpolo

 双击该批处理文件,运行游戏:

运行成功会显示游戏的基本信息,按任意键继续:

 

如果该ROM文件还存在问题,会出现提醒,该ROM的问题为"还未正确地模拟声音功能",按任意键继续:

 进入游戏:

 因为不太会玩该游戏,这里不做说明。

四、MAME查看DEBUG调试器

此时,我们只能看到游戏的运行,并不能观察到游戏的程序代码,我们如果需要查看游戏的程序代码,需要加入一些参数来启运MAME。我们下面将测试一款非常流行的游戏来测试如果查看游戏的程序代码,该游戏名为"Cadillacs and Dinosaurs(中文名:恐龙新世纪)"。这里因各种原因,无法提供该ROM的下载。

该游戏下载到的ROM文件文件名为dino.zip的压缩包,和之前的游戏一样,我们同样把该文件放到roms文件夹下。在mame.exe相同的文件夹中,新建一个批处理文件"dino.bat",在该文件中输入:

mame.exe dino -debug -window
pause

参数:

        -debug :打开debug调试选项

        -window :以窗口模式运行该游戏

因为如果出现错误,我们可能需要观察错误提示,我们加入一行"pause"命令。

在下载ROM文件时,经常见到的问题是会出现缺少某个ROM文件的情况:

比如这里是提供缺少dl-1425.bin文件,同样因为一些原因,这里无法提供该文件的下载。请自行搜索下载该文件。 把下载到的缺少的文件添加到dino.zip压缩包中:

再次测试运行:

如果正常运行,我们可以看到,除了游戏窗口,多了一个debug调试窗口,在这里,我们可以查看该游戏的运行代码。

这里说明一下该窗口菜单的一些功能:

New Memory Window                                - 新建内存窗口

New Disassembly Window                        - 新建汇编窗口

New Error Log Window                             - 新建错误日志窗口

New (Break|Watch)points Window           - 新建中断列表窗口

Run                                                           - 运行游戏(不关闭debug窗口)

Run and Hide Debugger                          - 运行游戏(同时关闭debug窗口)

Run to Next CPU                                        -运行(直到下一个CPU)

Run until Next interrupt on This CPU        - 运行(直到该CPU中的下一个中断)

Run until Next VBLAND                            - 运行(直到下一个VBLAND)

Step Into                                                    - 步入

Step Over                                                  - 步过

Step Out                                                    - 步出

Rewind Step                                              - 步回

Soft Reset                                                  - 软重启

Hard Reset                                                - 硬重启

Exit                                                            - 退出游戏

Set breakpoint at cursor                - 在光标处设置一个中断

Disable breakpoint at cursor         - 在光标处取消一个中断

Run to cursor                                - 运行到光标处

Raw opcodes                                -显示原始数据

Encrypted opcodes                       - 显示加密的数据

Comments                                    - 显示注释

Save Window Arrangement        -保存窗口的排列

Light Background                        - 亮色背景

Dark Background                        - 深色背景

我们如果需要关闭debug调试窗口,可以在选中调试窗的情况下,按"F12"键,来关闭调试窗口并进入游戏。

以上就是对于街机游戏逆向工程所需用到的MAME模拟器的基本介绍,在之后的章节,会一步步地尝试如何去逆向分析一个游戏的运行。并测试改变程序的运行逻辑,来改变程序的运行结果。

在后续的文章中,会要求可以熟练地使用MAME模拟器,比如按键的设置,能熟练地进行游戏的存档和读档,这些操作不要本教程的介绍范围。可以搜索对应的文章来了解。

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



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

相关文章

如何为Yarn配置国内源的详细教程

《如何为Yarn配置国内源的详细教程》在使用Yarn进行项目开发时,由于网络原因,直接使用官方源可能会导致下载速度慢或连接失败,配置国内源可以显著提高包的下载速度和稳定性,本文将详细介绍如何为Yarn... 目录一、查询当前使用的镜像源二、设置国内源1. 设置为淘宝镜像源2. 设置为其他国内源三、还原为官方

Maven的使用和配置国内源的保姆级教程

《Maven的使用和配置国内源的保姆级教程》Maven是⼀个项目管理工具,基于POM(ProjectObjectModel,项目对象模型)的概念,Maven可以通过一小段描述信息来管理项目的构建,报告... 目录1. 什么是Maven?2.创建⼀个Maven项目3.Maven 核心功能4.使用Maven H

MySql match against工具详细用法

《MySqlmatchagainst工具详细用法》在MySQL中,MATCH……AGAINST是全文索引(Full-Textindex)的查询语法,它允许你对文本进行高效的全文搜素,支持自然语言搜... 目录一、全文索引的基本概念二、创建全文索引三、自然语言搜索四、布尔搜索五、相关性排序六、全文索引的限制七

基于Java实现回调监听工具类

《基于Java实现回调监听工具类》这篇文章主要为大家详细介绍了如何基于Java实现一个回调监听工具类,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录监听接口类 Listenable实际用法打印结果首先,会用到 函数式接口 Consumer, 通过这个可以解耦回调方法,下面先写一个

IDEA自动生成注释模板的配置教程

《IDEA自动生成注释模板的配置教程》本文介绍了如何在IntelliJIDEA中配置类和方法的注释模板,包括自动生成项目名称、包名、日期和时间等内容,以及如何定制参数和返回值的注释格式,需要的朋友可以... 目录项目场景配置方法类注释模板定义类开头的注释步骤类注释效果方法注释模板定义方法开头的注释步骤方法注

使用Python构建一个Hexo博客发布工具

《使用Python构建一个Hexo博客发布工具》虽然Hexo的命令行工具非常强大,但对于日常的博客撰写和发布过程,我总觉得缺少一个直观的图形界面来简化操作,下面我们就来看看如何使用Python构建一个... 目录引言Hexo博客系统简介设计需求技术选择代码实现主框架界面设计核心功能实现1. 发布文章2. 加

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的

基于Python打造一个全能文本处理工具

《基于Python打造一个全能文本处理工具》:本文主要介绍一个基于Python+Tkinter开发的全功能本地化文本处理工具,它不仅具备基础的格式转换功能,更集成了中文特色处理等实用功能,有需要的... 目录1. 概述:当文本处理遇上python图形界面2. 功能全景图:六大核心模块解析3.运行效果4. 相

springboot项目中常用的工具类和api详解

《springboot项目中常用的工具类和api详解》在SpringBoot项目中,开发者通常会依赖一些工具类和API来简化开发、提高效率,以下是一些常用的工具类及其典型应用场景,涵盖Spring原生... 目录1. Spring Framework 自带工具类(1) StringUtils(2) Coll

Python虚拟环境终极(含PyCharm的使用教程)

《Python虚拟环境终极(含PyCharm的使用教程)》:本文主要介绍Python虚拟环境终极(含PyCharm的使用教程),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录一、为什么需要虚拟环境?二、虚拟环境创建方式对比三、命令行创建虚拟环境(venv)3.1 基础命令3