TweetFollow Us on Twitter

December 92 - KON & BAL'S PUZZLE PAGE

KON & BAL'S PUZZLE PAGE

A MICRO BUG

KONSTANTIN OTHMER AND BRUCE LEAK

[IMAGE 134-137_Puzzle_Page_rev1.GIF]


KONSTANTIN OTHMER AND BRUCE LEAKSee if you can solve this programming puzzle, presented in the form of a dialog between Konstantin Othmer (KON) and Bruce Leak (BAL). The dialog gives clues to help you. Try to guess this one before BAL does. To figure out your score, see "Scoring" at the end.


KON Have you heard of Spaceward Ho!?

BAL Yeah, it's that awesome conquer-the-galaxy game from Delta Tao. That game has done more to hurt productivity around here than pinball.

KON After they released it, they got several calls complaining about a crash. They tried to reproduce the crash but couldn't.

BAL They don't have that SADE MultiFinder installed, do they?

KON Very funny.

BAL How is their configuration different from the configuration of customers with the problem?

KON Everyone who complained had a 4-meg IIsi, ci, or fx. And the Delta Tao folks tested those configurations.

BAL Hmmm. How does it crash? Can you get into MacsBug?

KON That's part of the problem, the customers who have the crash aren't programmers and don't have MacsBug. The crash is with an Error 01, a bus error.

BAL Well, find one of the machines it crashes on, install MacsBug, and see what's wrong. How hard can it be?

KON So you fly to Bismarck, North Dakota, and install MacsBug, and it doesn't crash anymore. Pretty hard, I guess.

BAL Hmmm. Just MacsBug? Are there any INITs running?

KON The machine has only MacsBug, nothing else.

BAL And you never set a breakpoint, or an A-trap break, or anything?

KON Nope.

BAL Do you have a FirstTime macro?

KON Nope.

BAL So how could MacsBug be interfering?

KON I can't help you there. It's your puzzle.

BAL Well, MacsBug initializes some low-memory values and rearranges things above BufPtr. Is the app doing anything funny that might depend on some low mems?

KON The app follows every programming convention dictated by Inside Macintosh  and the Developer Support Center. They even follow every human interface guideline and . . .

BAL Yeah, yeah, yeah. Impossible. So MacsBug is installed, but it's never invoked.

KON Yep.

BAL What's the app doing when it crashes?

KON It's in the middle of a bunch of calculations -- you know, how many ships got destroyed in battle, how fast planets' populations are growing, what the computer players are doing, that kind of thing.

BAL Well, MacsBug causes the app to launch in a different place.

KON OK.

BAL MacsBug loads above BufPtr, so everything else loads lower. Maybe the app reads past the end of its heap. When MacsBug is in, it's lower in the heap, so the app reads somewhere in MacsBug territory. When MacsBug is out, the app reads past the end of RAM and causes a bus error.

KON Nice theory. But how do you verify that that's the problem without MacsBug?

BAL Launch another app first.

KON Then the Ho! will load even lower in memory. It won't crash.

BAL Use MicroBug.

KON You mean that thing that comes up when you push the NMI switch and MacsBug isn't installed? Where is that documented?

BAL I don't know. It can't be too hard to figure it out, though.

KON Well, the only command I know is G for "Go." What else will it let me do?

BAL You can look at memory and registers, you can set the PC, and you can even exit to the shell. Let's try a Total Display, TD. MicroBug responds with this:

000C30 0000 0000 0074 0000 FFFF 0100 0000 00C4
000C40 0000 FFFF 0000 0000 00AD E5D7 0074 0000
000C50 006E B2D0 0074 0A80 006E 9EB8 0057 0308
000C60 0000 0000 0074 0BAC 006E 49F8 006E 49E0
000C70 000A D96A 2014 0000 0000 0000 0000 0000
000C80 0000 0000 5444 0020 0020 0020 0020 0020

KON It looks like it's dumping memory from C30.

BAL Yeah, from SysEqu.a we see that C30 is SEVarBase. The system exception vars go up to CBF. I guess that's where the exception vectors dump the processor state when an exception occurs.

KON Since the system sets up the SEVars, they're set up on any exception regardless of the debugging environment. Using MacsBug, we can figure out that the first two lines are registers D0-D7, the next two lines are A0-A7, then the PC, then the status register, then what?

BAL I don't know, but at C84, it looks like what we typed: TD.

KON You could read a book written in ASCII!

BAL Let's try something else, maybe it can do math. Let's try DM PC-10.

KON It works.

BAL Yeah. In addition to the PC, it knows registers as RA0 or RD0 (but you set registers with a line like D0 = 5, not RD0 = 5). You can set memory using SM.

KON Anyway, back to the Ho!

BAL So in the Ho! I can look at the PC and the registers and figure out that it's looking past the end of memory.

KON You can't do an IL or an IP, so you can't prove that bogus values in a register are causing the bus error.

BAL I go into MacsBug on my PowerBook and disassemble the code with the DH command.

KON How do you find the problem code in the source?

BAL I pattern-match using the Find command on the PowerBook. Once I find the problem in MacsBug on the PowerBook, I'm golden.

KON Right! Here's the scoop: One of their pointers got messed up and they were reading off the end of their heap. The value they read had only a minor impact on the calculations, so no one noticed the problem. When MacsBug was in, they were reading in MacsBug's code space, which is a valid address and didn't cause a bus error. The reason it was reported on 4- meg IIsi's, ci's, and fx's is that only '030 or '040 machines that have the ci-class ROM cause bus errors when reading a valid RAM address that doesn't have RAM installed.

BAL And reading off the end of RAM on an 8-meg machine in 24-bit addressing mode just reads the ROM, which is valid.

KON Instead of this MicroBug detour, you could just write a flag value on the screen from various interesting places in the source. The flag value when you crash tells you where you were last.

BAL Yeah, but that's been done before. And it doesn't give us a good excuse to discuss MicroBug.

KON OK, Mr. MicroBug, what's the fewest keystrokes you can use to do an ExitToShell from MicroBug?

BAL Well, ExitToShell is Toolbox trap A9F4. The Toolbox trap table begins at $E00, so you can calculate the address of the trap and then use the G command.

KON Once you have the address, that's a minimum of seven keystrokes. You like to type a lot.

BAL I need some time to think about that one.

KON While you're thinking, how do you restart from MicroBug?

BAL Let's just leave everyone in suspense until next time.

KON Nasty.

BAL Yeah.

KONSTANTIN OTHMER AND BRUCE LEAK are basically slackers who go on way too many vacations. Unfortunately, they write buggy code and there are always a number of bugs that they need to fix on their return. But in true slacker style, they wouldn't think of fixing their own bugs. Enter the Puzzle Page, a sly coverup for getting someone else to solve these problems. Instead of fighting through buggy code with MacsBug, they call each other looking for easy answers. To keep pace with their bugs, they're lobbying the develop  staff to do a whole issue of just Puzzle Pages. *

SCORING

  • If you stick with MacsBug and never even try MicroBug, score 25.
  • If you figured out the bug before BAL did, score 50.
  • If you start to use MicroBug and like it better than MacsBug, score 75.
  • If you start to play Spaceward Ho! regularly, and like it better than MicroBug, score 100. *

Thanks to Gary Davidian, scott douglass, and Jean-Charles Mourey for reviewing this column.*

 

Community Search:
MacTech Search:

Software Updates via MacUpdate

Latest Forum Discussions

See All

Fallout Shelter pulls in ten times its u...
When the Fallout TV series was announced I, like I assume many others, assumed it was going to be an utter pile of garbage. Well, as we now know that couldn't be further from the truth. It was a smash hit, and this success has of course given the... | Read more »
Recruit two powerful-sounding students t...
I am a fan of anime, and I hear about a lot that comes through, but one that escaped my attention until now is A Certain Scientific Railgun T, and that name is very enticing. If it's new to you too, then players of Blue Archive can get a hands-on... | Read more »
Top Hat Studios unveils a new gameplay t...
There are a lot of big games coming that you might be excited about, but one of those I am most interested in is Athenian Rhapsody because it looks delightfully silly. The developers behind this project, the rather fancy-sounding Top Hat Studios,... | Read more »
Bound through time on the hunt for sneak...
Have you ever sat down and wondered what would happen if Dr Who and Sherlock Holmes went on an adventure? Well, besides probably being the best mash-up of English fiction, you'd get the Hidden Through Time series, and now Rogueside has announced... | Read more »
The secrets of Penacony might soon come...
Version 2.2 of Honkai: Star Rail is on the horizon and brings the culmination of the Penacony adventure after quite the escalation in the latest story quests. To help you through this new expansion is the introduction of two powerful new... | Read more »
The Legend of Heroes: Trails of Cold Ste...
I adore game series that have connecting lore and stories, which of course means the Legend of Heroes is very dear to me, Trails lore has been building for two decades. Excitedly, the next stage is upon us as Userjoy has announced the upcoming... | Read more »
Go from lowly lizard to wicked Wyvern in...
Do you like questing, and do you like dragons? If not then boy is this not the announcement for you, as Loongcheer Game has unveiled Quest Dragon: Idle Mobile Game. Yes, it is amazing Square Enix hasn’t sued them for copyright infringement, but... | Read more »
Aether Gazer unveils Chapter 16 of its m...
After a bit of maintenance, Aether Gazer has released Chapter 16 of its main storyline, titled Night Parade of the Beasts. This big update brings a new character, a special outfit, some special limited-time events, and, of course, an engaging... | Read more »
Challenge those pesky wyverns to a dance...
After recently having you do battle against your foes by wildly flailing Hello Kitty and friends at them, GungHo Online has whipped out another surprising collaboration for Puzzle & Dragons. It is now time to beat your opponents by cha-cha... | Read more »
Pack a magnifying glass and practice you...
Somehow it has already been a year since Torchlight: Infinite launched, and XD Games is celebrating by blending in what sounds like a truly fantastic new update. Fans of Cthulhu rejoice, as Whispering Mist brings some horror elements, and tests... | Read more »

Price Scanner via MacPrices.net

Verizon has Apple AirPods on sale this weeken...
Verizon has Apple AirPods on sale for up to 31% off MSRP on their online store this weekend. Their prices are the lowest price available for AirPods from any Apple retailer. Verizon service is not... Read more
Apple has 15-inch M2 MacBook Airs available s...
Apple has clearance, Certified Refurbished, 15″ M2 MacBook Airs available starting at $1019 and ranging up to $300 off original MSRP. These are the cheapest 15″ MacBook Airs for sale today at Apple.... Read more
May 2024 Apple Education discounts on MacBook...
If you’re a student, teacher, or staff member at any educational institution, you can use your .edu email address when ordering at Apple Education to take up to $300 off the purchase of a new MacBook... Read more
Clearance 16-inch M2 Pro MacBook Pros in stoc...
Apple has clearance 16″ M2 Pro MacBook Pros available in their Certified Refurbished store starting at $2049 and ranging up to $450 off original MSRP. Each model features a new outer case, shipping... Read more
Save $300 at Apple on 14-inch M3 MacBook Pros...
Apple has 14″ M3 MacBook Pros with 16GB of RAM, Certified Refurbished, available for $270-$300 off MSRP. Each model features a new outer case, shipping is free, and an Apple 1-year warranty is... Read more
Apple continues to offer 14-inch M3 MacBook P...
Apple has 14″ M3 MacBook Pros, Certified Refurbished, available starting at only $1359 and ranging up to $270 off MSRP. Each model features a new outer case, shipping is free, and an Apple 1-year... Read more
Apple AirPods Pro with USB-C return to all-ti...
Amazon has Apple’s AirPods Pro with USB-C in stock and on sale for $179.99 including free shipping. Their price is $70 (28%) off MSRP, and it’s currently the lowest price available for new AirPods... Read more
Apple Magic Keyboards for iPads are on sale f...
Amazon has Apple Magic Keyboards for iPads on sale today for up to $70 off MSRP, shipping included: – Magic Keyboard for 10th-generation Apple iPad: $199, save $50 – Magic Keyboard for 11″ iPad Pro/... Read more
Apple’s 13-inch M2 MacBook Airs return to rec...
Apple retailers have 13″ MacBook Airs with M2 CPUs in stock and on sale this weekend starting at only $849 in Space Gray, Silver, Starlight, and Midnight colors. These are the lowest prices currently... Read more
Best Buy is clearing out iPad Airs for up to...
In advance of next week’s probably release of new and updated iPad Airs, Best Buy has 10.9″ M1 WiFi iPad Airs on record-low sale prices for up to $200 off Apple’s MSRP, starting at $399. Sale prices... Read more

Jobs Board

Liquor Stock Clerk - S. *Apple* St. - Idaho...
Liquor Stock Clerk - S. Apple St. Boise Posting Begin Date: 2023/10/10 Posting End Date: 2024/10/14 Category: Retail Sub Category: Customer Service Work Type: Part Read more
*Apple* App Developer - Datrose (United Stat...
…year experiencein programming and have computer knowledge with SWIFT. Job Responsibilites: Apple App Developer is expected to support essential tasks for the RxASL Read more
Omnichannel Associate - *Apple* Blossom Mal...
Omnichannel Associate - Apple Blossom Mall Location:Winchester, VA, United States (https://jobs.jcp.com/jobs/location/191170/winchester-va-united-states) - Apple Read more
Operations Associate - *Apple* Blossom Mall...
Operations Associate - Apple Blossom Mall Location:Winchester, VA, United States (https://jobs.jcp.com/jobs/location/191170/winchester-va-united-states) - Apple Read more
Cashier - *Apple* Blossom Mall - JCPenney (...
Cashier - Apple Blossom Mall Location:Winchester, VA, United States (https://jobs.jcp.com/jobs/location/191170/winchester-va-united-states) - Apple Blossom Mall Read more
All contents are Copyright 1984-2011 by Xplain Corporation. All rights reserved. Theme designed by Icreon.