tandy put their sound chip on the 1A interrupt? THE TIME SERVICES?
=> More informations about this toot | More toots from foone@digipres.club
I started reverse engineering Where in the World is Carmen Sandiego (Enhanced DOS edition) and I'm trying to find how it generates its random seeds so I search on int 1a and the first thing I find is it's doing TANDY SOUNDS?
=> More informations about this toot | More toots from foone@digipres.club
Funny fact: I was trying to get an online assembler to spit out the machine code for "int 1a" but couldn't get it to, so I just went "fuck it, I can probably just do that in my head!"
Turns out I can. My brain is weird.
=> More informations about this toot | More toots from foone@digipres.club
Here's something I didn't know existed until just now: Where in the World is Carmen Sandiego checks your name against the list dossier list and rejects you if you use any of those names.
=> More informations about this toot | More toots from foone@digipres.club
PRONOUNS DETECTED: THIS GAME IS WOKE
sadly they don't have they/them on here. What about the non-binary criminals, huh?
=> More informations about this toot | More toots from foone@digipres.club
stretch goal: hack in at least on enby criminal with appropriate pronouns. maybe I'll just put myself in the game as one of the criminals you can apprehend
=> More informations about this toot | More toots from foone@digipres.club
I faked this screenshot but this is what I mean
=> More informations about this toot | More toots from foone@digipres.club
I think I might be able to do the hack I want by changing one byte.
I'm trying to change it so it has "daily challenges", and I think I can fix that by just switching a INT 1A from subfunction 00 to 04, making it seed the random function with the date instead of the ticks-since-midnight
=> More informations about this toot | More toots from foone@digipres.club
eh, I used 5 bytes. I don't need to impress anyone
=> More informations about this toot | More toots from foone@digipres.club
NORMAL CODE
random(*(byte )(undefined2 *)
(*(int *)(*(int *)0x39a6 * 0xe + local_c * 2 + 0x1d02) * 2 +
*(int *)(local_c * 2 + 0x24b)) - 1);
=> More informations about this toot | More toots from foone@digipres.club
I found another set of pronouns!
=> More informations about this toot | More toots from foone@digipres.club
I haven't figured out how this game stores gender, but I'm gonna go out on a limb and say it's like this:
male: 0
female: 4
=> More informations about this toot | More toots from foone@digipres.club
why? because they have strings like:
char* HE="He\0\0She\0"
char* HIS="His\0Hers\0";
char* HIM="Him\0Her\0";
so they can do like:
printf("Follow %s to %s lair, and capture %s alive!", badguy->name, HIS+badguy->gender, HIM+badguy->gender);
=> More informations about this toot | More toots from foone@digipres.club
I like how the game only asks your name, not your gender.
Player's don't have genders. Only thieves have genders.
=> More informations about this toot | More toots from foone@digipres.club
It's a prequel to Disco Elysium, and your gender is set to COP
=> More informations about this toot | More toots from foone@digipres.club
why does ghidra's "search by instruction pattern" default to BINARY?
what kind of a freak remembers the machine code for INT 21 on x86 in BINARY?
it's CD21h, not 1100110100100001!
what are you, some kind of nerd?
=> More informations about this toot | More toots from foone@digipres.club
I love reversing a string and it's:
void printString(char* str, int length);
and I go look what calls it, reverse that function, and it's:
void printStringSimple(char *str){
printString(str, strlen(str));
}
=> More informations about this toot | More toots from foone@digipres.club
it's like "aww, did someone have second thoughts about making PRINT always take a length, and got tired of having to manually calculate lengths so you just wrapped it?
and your compiler didn't inline SHIT?
=> More informations about this toot | More toots from foone@digipres.club
oh those poor people of Bamako! Someone stole their.
=> More informations about this toot | More toots from foone@digipres.club
okay so when you start a game (well, technically when you restart), the game rolls 3 dice:
0-31: where the shit was stolen from
0-2: which item it is from that location
0-8: whodunnit
=> More informations about this toot | More toots from foone@digipres.club
like if you roll 0 on the first, you get Athens.
For the second one, it's:
0: mask of Priam
1: Achilles's heel
2: sibyl's secret.
=> More informations about this toot | More toots from foone@digipres.club
The last die is used as a lookup table into the dossier's list.
It's got 1 added to it so you won't get Carmen Sandiego, as a rookie at least.
=> More informations about this toot | More toots from foone@digipres.club
so the game uses a pattern like this:
char * RANKS="Rookie\0Sleuth\0Private Eye\0Investigator\0Ace Detective\0"
and then latter they do:
char* your_rank = select_string(RANKS, player->rank);
and select_string is a confusing function to reverse engineer, but knowing the name I gave it gives it away: it advances through the list until it's on the nth string and returns it
=> More informations about this toot | More toots from foone@digipres.club
there is no check for going past the end.
=> More informations about this toot | More toots from foone@digipres.club
so probably it uses the same trick for pronouns. The string I'm seeing is probably like: "He\0Him\0She\0Her\0"
=> More informations about this toot | More toots from foone@digipres.club
Ghidra is officially sexist. It'll automatically detect the word "Female" and mark it as a string, but not the word "Male"!
Why? SEXISM!
or the fact the default minimum length for strings is 5 characters, so "female" is long enough but "male" isn't.
=> More informations about this toot | More toots from foone@digipres.club
correction: there IS a check for going over the end, it's just not used in every place select_string is called. so it's sometimes-safe
=> More informations about this toot | More toots from foone@digipres.club
they have invented a Pronoun Markup Language.
It's \x80 for He/She
It's \x81 for he/she
It's \x82 for his/her
so a string will be "\x80 mentioned \x81 liked seafood and offered me a ride in \x82 motorcycle"
and it'll fill it out based on the pronouns of the suspect
=> More informations about this toot | More toots from foone@digipres.club
BOOOOOOOOOOOOO
=> More informations about this toot | More toots from foone@digipres.club
@foone you're french and you're a member of the Gendermarie
=> More informations about this toot | More toots from jollysea@chaos.social
@jollysea I am definitely a member of the gender army
=> More informations about this toot | More toots from foone@digipres.club
@foone when i was younger and a lot more naive i used to think old games were all hyper-optimized, artfully crafted code wrote by ancient wizards who would eek out the most of every clock cycle
.... yeah.
=> More informations about this toot | More toots from nathan@e4b4.eu
@foone If someone stole their, that may be why there's no they/them in the game
=> More informations about this toot | More toots from LAbare@anticapitalist.party
@foone stealing their can only be the diabolical work of one Carmen Sandiego
=> More informations about this toot | More toots from timixretroplays@digipres.club
@foone clearly it believes that only women exist
=> More informations about this toot | More toots from Siph@meemu.org
@foone
But aren't then "fellows" then a string and "gals" are not?
=> More informations about this toot | More toots from futurebird@sauropods.win
@futurebird @foone "good" and "evil" aren't strings either. This just got metaphysical.
=> More informations about this toot | More toots from adriano@lile.cl
@futurebird @foone heck, "text" is not a string.
=> More informations about this toot | More toots from adriano@lile.cl
@foone heruururhg the "male" isn't long enough heeuehehehehe ¬w¬
=> More informations about this toot | More toots from Nine@chitter.xyz
@foone would that mean English is sexist? Because in German, both "männlich" (male) and "weiblich" (female) would match, but neither "Mann" nor "Frau" (man/woman)
=> More informations about this toot | More toots from punissuer@universeodon.com
@punissuer exactly! it's all english's fault.
=> More informations about this toot | More toots from foone@digipres.club
@foone it's English all the way down
https://www.reddit.com/r/Jokes/comments/3ssua0/the_problem_with_speaking_english/
=> More informations about this toot | More toots from punissuer@universeodon.com
@foone The Best Kind of safe
=> More informations about this toot | More toots from adriano@lile.cl
@foone why am I now imagining a very overengineered W3C candidate recommendation for pronoun markup using XML or something because it’s always XML
=> More informations about this toot | More toots from captainhayashi@toot.cat
@foone There's a very obvious problem here, and I know we're all thinking it, so I'm just going to come out and say it.
There's no capitalized His/Her option!! Now there's no way they could write the sentence "[His/Her] pet cat loves fugu," and the list of available hints pointing you to Japan is duller for it.
=> More informations about this toot | More toots from curtmack@floss.social
@foone ah yes the sometimes lifeboat
=> More informations about this toot | More toots from kate@federatedfandom.net
@kate @foone "and, in the end, after all, aren't all lifeboats sometimes lifeboats?"
=> More informations about this toot | More toots from marnanel@queer.party
@foone which is odd because caring about length is usually a male prerogative…
=> More informations about this toot | More toots from mmu_man@m.g3l.org
@foone@digipres.club You just made the funniest typo this year (so far at least). It doesn't detract in any way from the quality of your posting, but my brain is amused to think of the logical conclusion to a world where that wasn't a typo:
Because of a missing 0, makes it sound like the game has the pronouns: "he", "him/she", "her". meaning either you're bigender, or you have an incomplete set of pronouns
=> More informations about this toot | More toots from gwenthekween@kitsunes.club
@gwenthekween hah, whoops
=> More informations about this toot | More toots from foone@digipres.club
@foone gonna make a "Foone posts that sound deep and menacingly existential" account and become more known than Jesus in two weeks
=> More informations about this toot | More toots from ciatmusings@raru.re
@foone You may therefore reach secret ranks, like Modern Major General, or ŸŸŸŸŸŸŸŸ.
=> More informations about this toot | More toots from ozzelot@mstdn.social
@foone
Old school. Never check for an error condition if you don't know what to do about it.
=> More informations about this toot | More toots from petealexharris@mastodon.scot
@foone finally the O(2N) string printing function
=> More informations about this toot | More toots from charlotte@akko.chir.rs
@foone clearly we need the compromise of octal. 315 061
=> More informations about this toot | More toots from ChartreuseK@restless.systems
@ChartreuseK not even supported by this ghidra dialog. Binary or hex are the only options.
And note the weird part where it's "search by instruction pattern" but typing in instructions isn't possible.
You need the machine code for int 21h, not just "int 21h"
=> More informations about this toot | More toots from foone@digipres.club
@foone ACAB. Assigned Cop At Birth. (Which is how I always read that acronym before remembering what it should read...)
=> More informations about this toot | More toots from KateKarnage@mastodon.me.uk
@foone Having a gender is NPC behavior
=> More informations about this toot | More toots from ozzelot@mstdn.social
@foone those thieves are pretty good if they stole all the genders!
=> More informations about this toot | More toots from Larymir@chaos.social
@Larymir When no one was looking, Foone took forty genders. She took 40 genders.
And that's terrible.
=> More informations about this toot | More toots from foone@digipres.club
@foone Unlike Leather Goddesses of Phobos, where that’s the first thing the game asks.
=> More informations about this toot | More toots from arensb@mastodon.social
@foone so it also supports e/im/is, he/er/er, e/r/r and no pronouns as genders 1, 5 and 3/6?
=> More informations about this toot | More toots from lydiafacts@chaos.social
@lydiafacts technically yes! as well as large number of neopronouns used by indexing into other strings, possibly? it might be only one byte, which limits how far you can address
=> More informations about this toot | More toots from foone@digipres.club
@foone does this game not use structs??
=> More informations about this toot | More toots from mossfet@solarpunk.moe
@mossfet it might! this is just theorizing based on memory layout
=> More informations about this toot | More toots from foone@digipres.club
@foone ahhh
=> More informations about this toot | More toots from mossfet@solarpunk.moe
@foone Even if you only care about a binary, this still seems bad because you need quite a few pairs. With this setup, this print could very easily produce "Follow NAME to hers lair, and capture her alive!"
=> More informations about this toot | More toots from dillon@cloudisland.nz
@foone There was a time when I would have thought that extremely clever. These days, I look at that and shake my head at how English-centric it is.
=> More informations about this toot | More toots from arensb@mastodon.social
@foone ah, the same way that Intel stores privilege levels.
=> More informations about this toot | More toots from rotopenguin@mastodon.social This content has been proxied by September (3851b).Proxy Information
text/gemini