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
@foone but... if you put yourself in as a criminal, you will no longer be allowed to play!
=> More informations about this toot | More toots from shtrom@piaille.fr
@shtrom that's the price you pay for representation
=> 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@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
@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
@foone fae suspect who's stolen all the other genders from the National Pronoun Repository
=> More informations about this toot | More toots from DotMaetrix@chitter.xyz
@DotMaetrix You mean the Strategic National Pronoun Reserve?
=> More informations about this toot | More toots from foone@digipres.club
@foone
Gotta catch 'em all!
=> More informations about this toot | More toots from brouhaha@mastodon.social
@foone It’s been so long since I did any C programming, I can’t even tell the name of the variable being declared there.
=> More informations about this toot | More toots from arensb@mastodon.social
@foone This is why I hate C.
=> More informations about this toot | More toots from rodneylives@mefi.social
@foone
Wanted: Foone
Several counts of crimes against keyboards
=> More informations about this toot | More toots from chocobo13@mastodon.social This content has been proxied by September (3851b).Proxy Information
text/gemini