-
Saturn Grandia English Translation카테고리 없음 2020. 3. 16. 13:35
Have you checked the file bounds, as in, what happens when the script file is larger than the old one, and what happens if one particular text is long enough to push another one down? Are the script start points hardcoded pointers or some other control values that indicate 'text #001 starts here'?
Those were the issues I came across in SOTN, text locations were fixed and all string values used hardcoded pointers (and the values pointing to them were also pointers). The whole script file was a compiled mess, somewhere in the middle of the game code so you couldn't even recompile and pad it out since it would get overwritten by other code, it had a fixed length. Have you checked the file bounds, as in, what happens when the script file is larger than the old one, and what happens if one particular text is long enough to push another one down? Are the script start points hardcoded pointers or some other control values that indicate 'text #001 starts here'?
Those were the issues I came across in SOTN, text locations were fixed and all string values used hardcoded pointers (and the values pointing to them were also pointers). The whole script file was a compiled mess, somewhere in the middle of the game code so you couldn't even recompile and pad it out since it would get overwritten by other code, it had a fixed length.I haven't yet. Though if I were to take a guess I'd bet that the game will handle the expanded text fine as I'm not seeing anything in the text that looks like pointers, but something else will go wrong later on. The files that contain the script seem to contain more than just the script. Again taking a guess it seems that these files are for each specific area of the game, and contain the script for that area along with other data. So I'd imagine that if we expand text that bumps everything else in the file down, there is going to be a spectacular crash somewhere else down the line. I think this is where comparing the JP and EN PS1 files to figure out how they dealt with this issue will shed some light on what to do.
Also comparing the JP Saturn MDT files to the JP PS1 MDP files would probably be beneficial as well as it can shed light on what is different between the formats. EDIT: So I think I might be figuring out how the script pointers work based on comparing the PS1 versions, and then spot checking with the Saturn version. So here is what I believe to be one complete text routine from the file BA38.MDT at x05B4: This highlighted portion I believe is a header of some kind. It seems to change from text sample to text sample, so there's probably optional values that are in some text boxes but not in others. Now this next highlighted portion is the important part. This value I believe represents how many bytes until the end of this text box.
In this example it's 5A: If we then move forward 5A that will bring us to the end of this block of data. The end of a block of text data seems to be tagged with this possible footer: After this the next text box starts. I've been able to keep following this pattern and consistently keep finding what appears to be the correct number of bytes and the start of the next text box. I'm going to keep testing this but so far it's looking promising.
Also, another interesting thing of note is that it seems that the English PS1 versions files seem to be close to if not the same size as the Japanese PS1 files. It looks like Sony removed unnecessary padding to keep the files close to the same size from what I can tell.
Ok, so I think I've cracked the code of the MDT/MDP file headers. This information seems to hold true for both the Saturn and PS1 files, the only difference being that in the PS1 files pointers are Little Endian where as in the Saturn files they're Big Endian. The header is 512 Bytes in size. The header seems to consist of just a pointer table. Each entry is 8 bytes total in size. The first 4 bytes seem to be the place in the file where the data lives. The second 4 bytes seem to be the size of the data.
The entry that tells us where the text lives and how big it is seems to be at x60 every time. There's an entry at x58 that seems to point to a 24 byte piece of data right before the text. Perhaps this is a header or something?. Consistently I'm seeing in the English PS1 version that any addresses that come after the address defined at x60 have their values increased by the increase in size of the text data, and any values that come before it are untouched. I'm also seeing again padding being removed in the PS1 files of the exact amount added to the text. Another oddity I'm seeing is that the last entry in the table at x1F8 seems to also have it's size increased by the increase in text size. But I'm not sure what that value represents or what data was added.
Some other oddities I'm seeing is that some entries don't seem to make sense as the addresses are beyond the size of the file, but they're still updated in the English PS1 version. With this info I imagine I should be able to make a program that can do the following:.
Parse the MDT files. Extract the script portions.
Put the MDT file back together with a new script portion. Recalculate the pointer table. The hard part to automate in code I'd imagine would be to find a portion of padding in the file that can be removed to keep the file size the same.
So I wrote a program that allows me to parse the MDT and MDP files from the Saturn and Playstation versions. This basically strips the first 512 bytes and reads them as a pointer table. This information is then used to parse the rest of the file.
Best Sega Saturn Rpgs
Knowing that 0x60 marks the table entry for the script, I wrote some code to copy the bytes defined in the table and write them to a file. This has essentially allowed me to dump the raw script for the game out of all the MDT/MDP files. I've made it so it also writes the pointer table to a file, as well as the pre-script and post-script sections to files.
This way it should be easy to make some code to do the reverse and put all the pieces back together and recalculate the pointer table. On to the more interesting stuff though. After dumping the script for the Japanese Saturn, Japanese PS1, and English PS1 versions, I discovered that the Saturn and Japanese PS1 script data is identical. The initial cutscene I was looking at appears to be a special snowflake where they've added a bunch of additional control codes in the PS1 version. After that, things start lining up between the two. The only difference is the non-script parts of the data are byte swapped due to endian differences. This is making it really easy to start identifying pointer values and control codes by comparing the different versions.
I'm still figuring things out in these files, but I'm starting to think it might be possible to write a program that could automatically convert the English PS1 script files into a format the Saturn is expecting. I've attempted to attach some samples for people to look at if they wish. The extension says.SCRIPT but that is just something I came up with to keep things organized. They're just raw data that you can look at in a hex editor. So I think I might have some logic for how to do an automated conversion. Since the script format is the same, but with portions byte swapped, converting is straight forward from a manual process, but it's very time consuming. So automating it would probably save time, but it's a bit tricky.
From what I've found of the script files, there's no real common pattern I can use confidently to know exactly where the the text portion starts, and where the pre-text header/control code portion is. Basically some control codes are optional and aren't always used which makes knowing what to scan for difficult. But I do know the following 2 pieces of information seem to be consistent enough: 1) Each text sequence ends in the byte 0x07 2) There will always be at least a 2 byte sequence that will tell us the amount of bytes to the end of the text sequence, starting immediately after those bytes. From this point on is the portion that doesn't need to be byte swapped.
Now this isn't always in the same pattern sadly. I've seen at least the following variations 0x2X XX 0x3X XX 0x9X XX The X XX represents the size value in Hex. Sometimes with the 2 variant there is another 2 bytes of 0x3X XX that represents the size to the end of the sequence starting at the offset before those two bytes. Now since we know the file format is identical between versions for the script data, and the control codes are the same, the only differences is the portions that precede and include the size bytes are byte swapped, and obviously the English text isn't the same size. Control codes appear to be the same. However for the Saturn version the control code 03 needs to be added at the start of each line to tell it to use the 8x16 font.
So with all of this in mind this was my thought process for a how it could be converted automatically: 1) Split Script file for both English PS1 and Japanese Saturn or PS1 files on byte value 07 to break it down into it's individual script sequences. For English PS1 Script Pieces 2) Scan the script piece two bytes at a time, checking to see if the value of the low half byte of the first byte combined with the value of the second byte is equal to the remaining size of the piece when byte flipped.When doing the check, check the size starting at the offset immediately after these two bytes. 3) When we have a match, check the previous 2 bytes to see if they are also equal in distance from the offset immediately before them. If yes, make note of the value and it's offset.
Policenauts Saturn English Iso
4) Byte flip the piece from offset 0 to the last offset of the size byte. 5) From here on compare this piece to it's Japanese equivalent. Store size difference as a variable. 6) Scan byte by byte until we don't match, the data prior to this mismatch should be control codes. At this point insert 03.
Keep a count of each 03. 7) If Japanese file is larger, jump English offset ahead by Size difference. If English is larger, jump Japanese offset ahead by size. 8) Scan until we do get a match. We're Hoping that we've found a control code, so check that the matched value starts with 0.
9) If not the end of the piece, Return to 6) 10) If end of piece, return to size values and increase them by the number of 03's added. 11) Save and move to next piece. When all pieces are converted 12) Append all pieces back together 13) Reconstruct MDT file. Obviously this probably still needs some more thought to it, but I think it's enough that I can code something together and then test it out and see how it does. Errors will probably still happen, but if this can help convert the bulk of the text with only a few errors that need hand checked and fixed I'd count that as a win here.
If this can't be automated, the next option would be to do it all by hand which while doable, is very time consuming and opens itself up for it's own set of human errors. One thing that could make this less complex and easier to implement though is if the default font can be set to the 8x16 font. This would eliminate the need for using the 0x03 control code to use that font and changing the size bytes.
As a result this would then just become find the size byte, then byte swap the the necessary portion of the script piece. Code: 600C 4009 E001 2300Which would align with the Opcode for the replacement mov instruction. The problem is however, I can't seem to find this sequence of hex values anywhere in the game's executable, or anywhere in the games BIN/ISO for that matter. I found 2 values that were close, but they didn't seem to make any difference when I changed them. So I'm not sure what to do here. Moving on however, I have some more news concerning this.
I have continued work on my program for converting the files and I believe I may have successfully converted the PS1 script data over to the Saturn format. When combined with the memory edits above, I was able to get this: Now this still isn't perfect. As while this cutscene plays fine, the game seems to hang afterwards when it tries to load Parm.
The music and sound effects play, but the screen is black and the game doesn't seem to be progressing any further. Also not all the sound effects and voice clips seem to be playing during that first cutscene. So probably some debugging is needed to find out what's gone wrong. However the fact this seems to work in some cases looks promising that we can convert the English PS1 files over to the Saturn game rather easily.
I intend to release my code as I get it cleaned up as it's a bit sloppy at the moment. But if I get it working nicely, I'd imagine it could make it really easy for any future retranslation projects to apply their translation to both versions of the game. So I've been able to figure out how to get the game to use the 8x16 font by default. Turns out the reason I couldn't find the code that I needed to change is because it doesn't exist in the games compiled code. Instead those instructions are generated at run time based on values the game reads from other files. This could be a form of compression, or it could be some kind of automated code generation. I'm not really sure which.
Grandia Saturn Vs Psx Differences
However, I was able to find what value it's using to generate the code that determines what font to use. Turns out it's in the SCNRL.BIN file.
At offset 0x22A4 is the value 0x9D. This value get's XOR'd with the value 0x54 to create 0xC9. This corresponds to the And instruction for SH-2.
Changing this value to 0xB4 will instead result in the value 0xE0 being created, which is the Mov instruction we need instead to use the 8x16 Japanese font. Now the game is still crashing after the intro cutscene when it tries to load Parm. However I think this is due to the MDT file having an issue with it, as when I swap back in the original Japanese one it no longer crashes. So I'm going to need to dig back into these files and figure out whats wrong. I removed the MDT file that was causing the game to crash and replaced it with it's Japanese counterpart for the time being while I figure out whats wrong.
On the bright side though some of the other areas look to be working ok with some minor graphical glitches: From the looks of it, in this area the palette data is wrong. So I probably need to figure out where it's trying to read from the wrong spot and fix it. The English PS1 version added/removed chunks of null data from the files, probably to increase/reduce padding for this very issue. So I'm still working on trying to figure out the Palette bug in some of the areas. It seems to be related to file size expansion, but it's kind of odd. Basically the offset in the MDT file header at 0x0D8 seems to be the entry that points to this data.
And while the offset was updated in the file, it seems the game is only partially obeying it. Basically the game is still starting the read of the data from the correct spot in when it writes it into RAM. However it's stopping at what would be the originally stopping point for the original offset prior to the file size changing.
The size of this data hasn't changed and it's still correct in the header. As a result of this, old data from the previous MDT file is still in RAM and is being copied over as Palette data, which isn't correct and is causing the partial graphical corruptions I'm seeing. So I'm not entirely sure why this problem is happening. The only explanation is that it must be getting the value for where to stop reading from somewhere else. But where it's getting that info I haven't been able to track down yet. In other news, I've put the code for the tools I've been writing up on GitHub: The tools are written in Java and hopefully should be easy to figure out.
I'll be putting more info on the file formats as well as how to use the tools in the next few days when I have time. If anyone wants access as a contributor so they can add code/make changes let me know and I can add you.
So, most people are probably going to think this sounds silly, but maybe someone with more technical know-how will also be interested. I'll use X-Men vs Street Fighter as an example. The Saturn version is an absolutely fantastic port of the arcade game, but it's Japanese only.
That doesn't get in the way of the gameplay, but I like to be able to read the after battle messages and endings. I'm a technical guy, but I've never done any console software hacking before. I don't know what file(s) on the disc contain the in-game text.
I also have no idea if maybe the language files are structured like the inferior PS1 port where you could do some easy copy/pasting (and properly editing the disc image when doing so) to translate the Saturn port. If anyone has some insight please let me know, or if you're a techincal wiz that whip this up in a lazy Sunday afternoon then even better.
(truemaster1 converting JPN Code Veronica X on DC to English was my inspiration to ask about this here ). The original arcade version of X-Men Vs Street Fighter and Marvel Vs Street Fighter actually contain both the English and Japanese text in the same build/program. It's possible the Saturn version actually contains the English strings already. In the arcade program a memory location is loaded to retrieve the desired region and that then affects various things including if the language is Japanese or English. When the game was ported it might still have this design. If you want to do this you'd want to learn about the SH-2 the Saturn uses as well as look into any emulators with useful debugging features. It's possible with the right knowledge and a useful debugging emulator you could find the previously mentioned language switch or find the things you need to replace the Japanese strings and characters with English.
So, most people are probably going to think this sounds silly, but maybe someone with more technical know-how will also be interested. I'll use X-Men vs Street Fighter as an example.
The Saturn version is an absolutely fantastic port of the arcade game, but it's Japanese only. That doesn't get in the way of the gameplay, but I like to be able to read the after battle messages and endings. I'm a technical guy, but I've never done any console software hacking before.
I don't know what file(s) on the disc contain the in-game text. I also have no idea if maybe the language files are structured like the inferior PS1 port where you could do some easy copy/pasting (and properly editing the disc image when doing so) to translate the Saturn port. If anyone has some insight please let me know, or if you're a techincal wiz that whip this up in a lazy Sunday afternoon then even better.
(truemaster1 converting JPN Code Veronica X on DC to English was my inspiration to ask about this here ).