diff options
Diffstat (limited to 'gba/source')
-rw-r--r-- | gba/source/link.c | 15 | ||||
-rw-r--r-- | gba/source/main.c | 17 | ||||
-rw-r--r-- | gba/source/serialize.c | 12 | ||||
-rw-r--r-- | gba/source/serialize.h | 3 |
4 files changed, 23 insertions, 24 deletions
diff --git a/gba/source/link.c b/gba/source/link.c index 26443c8..05e4732 100644 --- a/gba/source/link.c +++ b/gba/source/link.c | |||
@@ -12,9 +12,9 @@ | |||
12 | 12 | ||
13 | void initializeLink() | 13 | void initializeLink() |
14 | { | 14 | { |
15 | REG_HS_CTRL |= JOY_RW; | ||
16 | REG_JOYTR = 0; | 15 | REG_JOYTR = 0; |
17 | while ((REG_HS_CTRL & JOY_WRITE) == 0); | 16 | REG_HS_CTRL |= JOY_RW; |
17 | while ((REG_HS_CTRL & JOY_READ) == 0); | ||
18 | REG_HS_CTRL |= JOY_RW; | 18 | REG_HS_CTRL |= JOY_RW; |
19 | } | 19 | } |
20 | 20 | ||
@@ -22,29 +22,22 @@ void waitForAck() | |||
22 | { | 22 | { |
23 | while ((REG_HS_CTRL & JOY_WRITE) == 0); | 23 | while ((REG_HS_CTRL & JOY_WRITE) == 0); |
24 | REG_HS_CTRL |= JOY_RW; | 24 | REG_HS_CTRL |= JOY_RW; |
25 | REG_JOYTR = 0; | ||
26 | while ((REG_HS_CTRL & JOY_WRITE) == 0); | ||
27 | REG_HS_CTRL |= JOY_RW; | ||
28 | } | 25 | } |
29 | 26 | ||
30 | u32 waitForResponse() | 27 | u32 waitForResponse() |
31 | { | 28 | { |
32 | u32 val; | 29 | u32 val; |
33 | 30 | ||
34 | REG_JOYTR = 1; | ||
35 | while ((REG_HS_CTRL & JOY_WRITE) == 0); | ||
36 | val = REG_JOYRE; | ||
37 | REG_HS_CTRL |= JOY_RW; | ||
38 | REG_JOYTR = 0; | ||
39 | while ((REG_HS_CTRL & JOY_WRITE) == 0); | 31 | while ((REG_HS_CTRL & JOY_WRITE) == 0); |
40 | REG_HS_CTRL |= JOY_RW; | 32 | REG_HS_CTRL |= JOY_RW; |
33 | val = REG_JOYRE; | ||
41 | 34 | ||
42 | return val; | 35 | return val; |
43 | } | 36 | } |
44 | 37 | ||
45 | void sendS32(s32 val) | 38 | void sendS32(s32 val) |
46 | { | 39 | { |
47 | REG_JOYTR = val; | 40 | sendU32(val); |
48 | } | 41 | } |
49 | 42 | ||
50 | void sendU32(u32 val) | 43 | void sendU32(u32 val) |
diff --git a/gba/source/main.c b/gba/source/main.c index aeb05af..0934e91 100644 --- a/gba/source/main.c +++ b/gba/source/main.c | |||
@@ -113,6 +113,21 @@ int main(void) | |||
113 | sendU32(trainerIdNum); | 113 | sendU32(trainerIdNum); |
114 | waitForAck(); | 114 | waitForAck(); |
115 | 115 | ||
116 | // Send cart language. | ||
117 | u8 cartLang = 0; | ||
118 | switch (*(u8*)(0x80000AF)) | ||
119 | { | ||
120 | case 'J': cartLang = Japanese; break; | ||
121 | case 'E': cartLang = English; break; | ||
122 | case 'F': cartLang = French; break; | ||
123 | case 'I': cartLang = Italian; break; | ||
124 | case 'D': cartLang = German; break; | ||
125 | case 'S': cartLang = Spanish; break; | ||
126 | } | ||
127 | |||
128 | sendU32(cartLang); | ||
129 | waitForAck(); | ||
130 | |||
116 | // Does the player want to import this game? | 131 | // Does the player want to import this game? |
117 | if (waitForResponse() == 0) | 132 | if (waitForResponse() == 0) |
118 | { | 133 | { |
@@ -193,7 +208,7 @@ int main(void) | |||
193 | 208 | ||
194 | struct PokemonIntermediate pki; | 209 | struct PokemonIntermediate pki; |
195 | 210 | ||
196 | PokemonIntermediateInit(&pki, bpkm, trainerIdNum, secretIdNum, &gameData); | 211 | PokemonIntermediateInit(&pki, bpkm, trainerIdNum, secretIdNum); |
197 | PokemonIntermediateStream(&pki); | 212 | PokemonIntermediateStream(&pki); |
198 | } | 213 | } |
199 | } | 214 | } |
diff --git a/gba/source/serialize.c b/gba/source/serialize.c index 4a80bdf..c5e8570 100644 --- a/gba/source/serialize.c +++ b/gba/source/serialize.c | |||
@@ -11,14 +11,6 @@ | |||
11 | #include "exptables.h" | 11 | #include "exptables.h" |
12 | #include "dexorder.h" | 12 | #include "dexorder.h" |
13 | 13 | ||
14 | enum Stat { | ||
15 | StatAttack, | ||
16 | StatDefense, | ||
17 | StatSpeed, | ||
18 | StatSpAttack, | ||
19 | StatSpDefense | ||
20 | }; | ||
21 | |||
22 | u32 CalculateStat( | 14 | u32 CalculateStat( |
23 | u8 base, | 15 | u8 base, |
24 | u32 iv, | 16 | u32 iv, |
@@ -50,8 +42,7 @@ void PokemonIntermediateInit( | |||
50 | struct PokemonIntermediate* pki, | 42 | struct PokemonIntermediate* pki, |
51 | struct BoxPokemon* bpkm, | 43 | struct BoxPokemon* bpkm, |
52 | u16 trainerId, | 44 | u16 trainerId, |
53 | u16 secretId, | 45 | u16 secretId) |
54 | const struct GameData* gameData) | ||
55 | { | 46 | { |
56 | DecryptBoxPokemon(bpkm); | 47 | DecryptBoxPokemon(bpkm); |
57 | 48 | ||
@@ -88,6 +79,7 @@ void PokemonIntermediateInit( | |||
88 | pki->metLocation = sub3->metLocation; | 79 | pki->metLocation = sub3->metLocation; |
89 | pki->pokeball = sub3->pokeball; | 80 | pki->pokeball = sub3->pokeball; |
90 | pki->altAbility = sub3->altAbility; | 81 | pki->altAbility = sub3->altAbility; |
82 | pki->language = bpkm->language & 3; | ||
91 | 83 | ||
92 | // Derive nature from the personality value. | 84 | // Derive nature from the personality value. |
93 | pki->nature = (bpkm->personality % 25); | 85 | pki->nature = (bpkm->personality % 25); |
diff --git a/gba/source/serialize.h b/gba/source/serialize.h index 38a4d6b..7fcae0f 100644 --- a/gba/source/serialize.h +++ b/gba/source/serialize.h | |||
@@ -17,8 +17,7 @@ void PokemonIntermediateInit( | |||
17 | struct PokemonIntermediate* pki, | 17 | struct PokemonIntermediate* pki, |
18 | struct BoxPokemon* bpkm, | 18 | struct BoxPokemon* bpkm, |
19 | u16 trainerId, | 19 | u16 trainerId, |
20 | u16 secretId, | 20 | u16 secretId); |
21 | const struct GameData* gameData); | ||
22 | 21 | ||
23 | void PokemonIntermediateStream(struct PokemonIntermediate* pki); | 22 | void PokemonIntermediateStream(struct PokemonIntermediate* pki); |
24 | 23 | ||