天天看点

土星游戏精灵王2游戏反向工程日志(1)

使用GHIDRA,反编译精灵王2 ISO,得到代码,由于世嘉土星的程序入口地址是06004000,(参考世嘉SGL文档),搜索字符串,及分析函数流程可知该游戏调用SGL的API加载TH2.LOW,流程是06080bcc=>TH2.LOW=>002e20f8 ,002e20f8 为SEGA SATURN LOW WORK RAM,

至此恍然大悟,原来.LOW不是扩展名文件类型,而是当时写这个的程序员怕记错加载地址,提示自己这段代码是要加载到LWRAM中,那么HWRAM600000与LWRAM 2000000(002e20f8 为HT2.LOW的入口地址 )区别是什么?通过阅读世嘉SGL文档知道,土星bios入口地址为0x06000000,而BIOS加载相当于IPL,加载后会有BSS,TEXT,DATA,RODATA段,及堆栈分布,然后加载SGL后会将入口地址土星游戏主程序 saturn_main() 定在06004000,这个过程由IDE及工具链指定,普通程序员无需关心,下一篇介绍TH2.LOW中代码分析,也就是汉化人员对该文件的分析,这个文件是本游戏核心

土星游戏精灵王2游戏反向工程日志(1)
土星游戏精灵王2游戏反向工程日志(1)
土星游戏精灵王2游戏反向工程日志(1)

()

土星游戏精灵王2游戏反向工程日志(1)

(利用ghidra中的show reference to 找到该函数调用)

继续阅读