The PokéCommunity Forums [Tutorial] HackMew's Knowledge

Notices
For all updates, view the main page.

 Tools, Tutorials & Resources Various tools to help you develop your hacks can be found here.New threads in this forum are to be approved by a moderator before they are displayed.

#101
April 7th, 2012 (06:42 PM).
 NintendoBoyDX Join Date: Jul 2010 Gender: Male Posts: 94
This is way more complicated than it needs to be... 080440F4 is the shiny decision routine. Go to 0804411E and replace it with 00 20. This is the spot that it checks whether the value is greater or less than 7. Replacing that will make the value always 00 right before the check, and that means all pokemon will be shiny. Much easier to replace 2 bytes.

just throwin that out there
#102
April 10th, 2012 (05:56 PM).
 YouListeningROMs Join Date: Mar 2012 Gender: Male Posts: 24
With ASM, how would you do modulo?
#103
April 10th, 2012 (10:39 PM).
 NintendoBoyDX Join Date: Jul 2010 Gender: Male Posts: 94
Quote originally posted by YouListeningROMs:
With ASM, how would you do modulo?
There are a couple of ways in fr. There is software interrupt 0x6, which is a bios function call that does division and modulo. There is routine 081E4018 developed by gamefreak, that does division and modulo as well.

R0 = dividend
R1 = divisor

returning
R0 = quotient

081E4684 is another routine made by gamefreak that does modulo only.

A few other math routines:
081E460C: another division routine
081E3B9C: square root, calls swi 0x8

I've stumbled across a few others that I dont remember..
#104
April 11th, 2012 (03:57 AM).
 YouListeningROMs Join Date: Mar 2012 Gender: Male Posts: 24
Quote originally posted by NintendoBoyDX:
There are a couple of ways in fr. There is software interrupt 0x6, which is a bios function call that does division and modulo. There is routine 081E4018 developed by gamefreak, that does division and modulo as well.

R0 = dividend
R1 = divisor

returning
R0 = quotient

081E4684 is another routine made by gamefreak that does modulo only.

A few other math routines:
081E460C: another division routine
081E3B9C: square root, calls swi 0x8

I've stumbled across a few others that I dont remember..
#105
November 13th, 2012 (08:07 AM).
 truekidmoney Join Date: Apr 2011 Gender: Male Posts: 3
Hey guys i have a question how do i get the results lesson1.bin this:
03 B5 03 48 00 68 03 49 80 89 08 80 03 BD C0 46
0C 50 00 03 D0 70 03 02
into my rom?
#106
November 13th, 2012 (08:13 AM).
 hashtag the man in black Crystal Tier Join Date: Nov 2008 Location: Salisbury, England Age: 20 Gender: Male Posts: 6,683
Use a Hex Editor and insert the bytes into free space ending with a 0, 4, 8 or C.
__________________
#
#107
November 30th, 2012 (07:55 AM).
 CallarinCreator Join Date: Sep 2012 Gender: Male Posts: 5
kan u post something on xse? it aint wantin to work for me. it will work. but it shuts down after like a second.
__________________
iiiiiiii uummm.... i scared.

house of EVIL!!! muhuahahahahhahahaha!!!!!!!!!
#108
November 30th, 2012 (09:27 AM).
 Deokishisu Mr. Magius Join Date: Feb 2006 Location: If I'm online, it's a safe bet I'm at a computer. Gender: Male Nature: Relaxed Posts: 501
Quote originally posted by CallarinCreator:
kan u post something on xse? it aint wantin to work for me. it will work. but it shuts down after like a second.
O poor English, struck down in its prime.

Anyway, this is because of the auto update feature. Since Hackmew's site is down, it tries to update, fails, and closes. To fix it, go into your .ini file and change it so that the AutoUpdateCheck equals zero.

So that line should look like this:
AutoUpdateCheck=0
#109
January 30th, 2013 (04:52 PM).
 GoGoJJTech http://GoGoJJTech.com (WIP!) Gold Tier Join Date: Nov 2012 Location: Earth Age: 16 Gender: Female Nature: Jolly Posts: 2,076
These are extremely helpful ( and long ) well great job hackmew
__________________
I believe in Jesus Christ my Savior. If you do too, and aren't scared to admit it, then copy and paste this into your signature.
The HGSS Music Patch - The BW/2 Music Patch - ASM: Switch Music Based on Seasons
Romhack.me Profile - Pokecommunity Profile - Pokemonhackersonline Profile - Youtube Channel

Pokémon Platinum Red and Blue
#110
February 3rd, 2013 (12:37 AM).
 Chaos Rush im sexy and i know it Join Date: May 2007 Location: Taylor Swift Gender: Male Nature: Adamant Posts: 1,283
I decided to take a crack at HackMew's ASM challenge, and I succeeded!

This is what I modified the routine to:
Code:
```.text
.align 2
.thumb
.thumb_func
.global lesson1

main:
push {r0-r1, lr}
ldr r0, .PLAYER_DATA
ldr r0, [r0]
ldr r1, .VAR
ldrh r0, [r0, #0xC]
strh r0, [r1]
ldr r0, .PLAYER_DATA
ldr r0, [r0]
ldr r1, .NEXT
ldrh r0, [r0, #0xA]
strh r0, [r1]
pop {r0-r1, pc}

.align 2
.PLAYER_DATA:
.word 0x0300500C
.VAR:
.word 0x020270B6 + (0x800D * 2)
.NEXT:
.word 0x020270B8 + (0x8000 * 2)```
And the XSE script:
Code:
```#dynamic 0x800000
#org @main
callasm YourASMoffset
buffernumber 0x0 LASTRESULT
buffernumber 0x1 0x8000
msgbox @msg MSG_FACE
end

#org @msg
Going to do my best to get ASM down...
__________________
#111
February 3rd, 2013 (06:46 AM).
 FBI agent If my PM box is full, VM instead :x Join Date: Jan 2013 Location: Unknown Island Gender: Male Posts: 823
Quote originally posted by Chaos Rush:
I decided to take a crack at HackMew's ASM challenge, and I succeeded!

Spoiler:
This is what I modified the routine to:
Code:
```.text
.align 2
.thumb
.thumb_func
.global lesson1

main:
push {r0-r1, lr}
ldr r0, .PLAYER_DATA
ldr r0, [r0]
ldr r1, .VAR
ldrh r0, [r0, #0xC]
strh r0, [r1]
ldr r0, .PLAYER_DATA
ldr r0, [r0]
ldr r1, .NEXT
ldrh r0, [r0, #0xA]
strh r0, [r1]
pop {r0-r1, pc}

.align 2
.PLAYER_DATA:
.word 0x0300500C
.VAR:
.word 0x020270B6 + (0x800D * 2)
.NEXT:
.word 0x020270B8 + (0x8000 * 2)```
And the XSE script:
Code:
```#dynamic 0x800000
#org @main
callasm YourASMoffset
buffernumber 0x0 LASTRESULT
buffernumber 0x1 0x8000
msgbox @msg MSG_FACE
end

#org @msg

Going to do my best to get ASM down...
Spoiler tags, pls!
Also, you don't need to load player data twice.
It should till work without doing this the second time:
ldr r0, .PLAYER_DATA
ldr r0, [r0]

EDIT: I lied, the way you did it, you did need to load it twice (or subtract :D).
__________________
...

My name forum name is FBI Agent, though you can call me FBI because it's shorter.

Some of my stuff:
ASM Workshop
#112
February 9th, 2013 (08:22 PM). Edited February 11th, 2013 by karatekid552.
 karatekid552 What happens if I push it?.... Join Date: Nov 2012 Location: Do you really want to know? Really? Gender: Male Nature: Bold Posts: 1,767
Almost all of the reference links for the ASM tutorial are broken. I have found a few of them, would it be alright for me to post them here? Or should I pm them to DrFuji/giradalkia to add to the end of the tut?

Edit: only two are broken.... Wow, I remember that being a lot more last time....

Edit2: I guess since no one has objected it is fine for me to post the links here:

Assembly Wikipedia: (So easy to find it really wasn't broken, but whatever) http://en.wikipedia.org/wiki/Assembly_language

ARM7DTMI Technical Manuel: http://infocenter.arm.com/help/topic/com.arm.doc.ddi0210c/DDI0210B.pdf

Tonic: Whirlwind Tour of ARM Assembly: http://www.coranac.com/tonc/text/asm.htm

Hope these help anyone who wants to learn ASM.
__________________

Paired with Simba
#113
May 17th, 2013 (10:12 AM). Edited May 17th, 2013 by Kurapika.
 Kurapika Grudgebearer Join Date: Feb 2013 Location: Lavendar Town - Morocco Gender: Male Nature: Naughty Posts: 397
Since I see people asking questions here, I have a problem using ldr with cmp. I am making a code that compares two words, one located in the RAM and the other located in the ROM. so what I do:
Spoiler:
ldr r1, .word1 ldr r1, [r1] ldr r2, .word2 ldr r2, [r2] cmp r1, r2 beq YayTheyEqualz ...
The problem is, the jump never occurs even when the words are equal... So I tried this:
Spoiler:
ldr r1, .word1 ldrh r1, [r1] ldr r2, .word2 ldrh r2, [r2] cmp r1, r2 beq SecondHalf ... SecondHalf: ldr r1, .word1 ldr r1, [r1, #0x2] ldr r2, .word2 ldrh r2, [r2, #0x2] cmp r1, r2 beq YayTheyEqualz ...
And this 2nd code works correctly but takes more space and it is more complicated. So, I'm wondering if ldr and/or cmr commands have some particular behaviour that makes the first code not working??? Or am I just doing something wrong?
__________________
#114
May 17th, 2013 (03:30 PM).
 karatekid552 What happens if I push it?.... Join Date: Nov 2012 Location: Do you really want to know? Really? Gender: Male Nature: Bold Posts: 1,767
Quote originally posted by Kurapika:
Since I see people asking questions here, I have a problem using ldr with cmp. I am making a code that compares two words, one located in the RAM and the other located in the ROM. so what I do:
Spoiler:
ldr r1, .word1 ldr r1, [r1] ldr r2, .word2 ldr r2, [r2] cmp r1, r2 beq YayTheyEqualz ...
The problem is, the jump never occurs even when the words are equal... So I tried this:
Spoiler:
ldr r1, .word1 ldrh r1, [r1] ldr r2, .word2 ldrh r2, [r2] cmp r1, r2 beq SecondHalf ... SecondHalf: ldr r1, .word1 ldr r1, [r1, #0x2] ldr r2, .word2 ldrh r2, [r2, #0x2] cmp r1, r2 beq YayTheyEqualz ...
And this 2nd code works correctly but takes more space and it is more complicated. So, I'm wondering if ldr and/or cmr commands have some particular behaviour that makes the first code not working??? Or am I just doing something wrong?
Would you mind giving us all of the ASM in the regular format? It is really tough the read this way.
__________________

Paired with Simba
#115
May 17th, 2013 (04:31 PM).
 Kurapika Grudgebearer Join Date: Feb 2013 Location: Lavendar Town - Morocco Gender: Male Nature: Naughty Posts: 397
code 1: code 2: The first one doesn't jump to TheyAreEqualz even when it should, the second code works perfectly for me. (Sorry, for some reason, line skips are removed from my posts ;_; I think it's just my ****** Internet -.-')
__________________
#116
May 17th, 2013 (06:00 PM).
 karatekid552 What happens if I push it?.... Join Date: Nov 2012 Location: Do you really want to know? Really? Gender: Male Nature: Bold Posts: 1,767
Quote originally posted by Kurapika:
code 1: code 2: The first one doesn't jump to TheyAreEqualz even when it should, the second code works perfectly for me. (Sorry, for some reason, line skips are removed from my posts ;_; I think it's just my ****** Internet -.-')
From looking at your code, both routines are loading different things. Parts are loading words and others are loading half-words and neither lines up with the other routine. That is probably where your problem lies. A word is 4 bytes and a half-word is 2 bytes. Take that as you wish.
__________________

Paired with Simba
#117
October 4th, 2013 (08:38 AM).
 Kurapika Grudgebearer Join Date: Feb 2013 Location: Lavendar Town - Morocco Gender: Male Nature: Naughty Posts: 397
Spoiler:
.word 0x020270B6 + (0x800D * 2)
Assigns the word (32 bits) 0x020270B6 + (0x800D * 2) = 0x020370D0 to .VAR. If you're wondering about the "weird" format, I made that to make it easier changing the variable used. Note however this would work only for temporary variables, 0x800D onwards. For the previous temporary variables, just increase the main address by 2 (in the example above, you would change it to .word 0x020270B8 + (0x8000 * 2), if you were to use variable 0x8000).

But does this way work for any other variables other than the 0x8000 family?
__________________
#118
October 4th, 2013 (09:22 AM).
 karatekid552 What happens if I push it?.... Join Date: Nov 2012 Location: Do you really want to know? Really? Gender: Male Nature: Bold Posts: 1,767
Quote originally posted by Kurapika:
Spoiler:
.word 0x020270B6 + (0x800D * 2)
Assigns the word (32 bits) 0x020270B6 + (0x800D * 2) = 0x020370D0 to .VAR. If you're wondering about the "weird" format, I made that to make it easier changing the variable used. Note however this would work only for temporary variables, 0x800D onwards. For the previous temporary variables, just increase the main address by 2 (in the example above, you would change it to .word 0x020270B8 + (0x8000 * 2), if you were to use variable 0x8000).

But does this way work for any other variables other than the 0x8000 family?
The others are DMA protected. Check my battle bg changer to see how to check vars of others. There is an in-game decrypter function.
__________________

Paired with Simba
#119
October 4th, 2013 (09:57 AM).
 Kurapika Grudgebearer Join Date: Feb 2013 Location: Lavendar Town - Morocco Gender: Male Nature: Naughty Posts: 397
Oh damn!
I'll check your tutorial, thank you bro!
__________________
#120
December 2nd, 2014 (08:03 AM). Edited December 2nd, 2014 by Christos.
 Lance32497 LanceKoijer of Pokemon_Addicts Join Date: Aug 2014 Location: Criscanto town-Ginoa Region xD Gender: Male Nature: Adamant Posts: 563
I got the error 'thumb' not recognized as an internal blah blah
#121
December 2nd, 2014 (01:47 PM).
 FBI agent If my PM box is full, VM instead :x Join Date: Jan 2013 Location: Unknown Island Gender: Male Posts: 823
Quote originally posted by Lance32497:
I got the error 'thumb' not recognized as an internal blah blah
You need to navigate in the command prompt to the directory containing "thumb.bat" and the rest of those files. From what it looks, you're trying to run it from a directory which doesn't have it.

I would move all the files into 1 folder and do:
cd path\To\File
thumb source.asm compiled.bin

Next time:
__________________
...

My name forum name is FBI Agent, though you can call me FBI because it's shorter.

Some of my stuff:
ASM Workshop
#122
2 Weeks Ago (06:31 AM).
 FamiliaWerneck Join Date: May 2015 Location: São Paulo, Brasil Gender: Male Posts: 156
So I have tried using the palette editing tutorial together with APE.
I did change the palettes of the National Pokédex, but I failed as for the right ones.
The broken images in OP could really be of help here.
Instead of changing that "green" frame of the National Pokédex for the brown one from the Regional Pokédex, I changed the background of the Pokédex to red and brown (and I didn't even use red while editting palettes...)
I opened the palettes, just like HackMew's tutorial said to, and I changed every green color for brown colors (only colors that were already in the palette) and this happened.
Help?