TweetFollow Us on Twitter

Boot Disk Icon
Volume Number:5
Issue Number:5
Column Tag:Programmer's Forum

Related Info: Finder Interface Device Manager

Change the Boot Disk Icon

By David Dunham, Goleta, CA

I’ve been asked several times how my bootDiskIcon INIT works. I told the questioners that I’d answer in MacTutor.

Also, this is a short article. MacTutor needs more of them -- I know how to initialize Managers and handle events, and I certainly don’t need to see pictures in hexadecimal. (This isn’t just a snide remark directed at the editor, it’s a plea to those with nifty ideas that don’t need an entire application to show them off. Write a one or two page article!)

bootDiskIcon is a hack that came about because I don’t own an HD20. Apple insists on portraying their internal hard disk as an HD 20 on my desktop. I got so disgusted with this that I wrote an INIT to show something else, anything but an HD 20. ICN# 256, in fact. bootDiskIcon is inferior to programs like Façade-- it’s less flexible, and may not work with all hard disks -- but it was better than nothing, and it’s easy to understand.

The key to bootDiskIcon is the way the Finder handles disk icons. A pedantic digression: how does one find out how Finder handles icons? It’s not in Inside Macintosh. Therefore, it must be in a Technical Note. But Finder isn’t a category in the table of contents. So it’s off to the index but it’s not listed under “icon.” Luckily, it was one of the “Finder” Tech Notes, number 28. How did I know to keep looking? Because I’d seen it years ago when it came out, and knew it was there somewhere. Always skim every Tech Note -- not to memorize them, but to remember that they’re there.

When the Finder wants a disk icon, it gives the disk driver a Control call with csCode = 21. The driver returns a pointer to an ICN#. My first inclination was, why write code when you can change data? The ICN# must be part of the disk driver. The disk driver is part of Apple HD SC Setup. I found it there (it’s not a resource), changed it, and reinstalled the driver. This failed utterly -- there’s apparently a checksum.

If I couldn’t change the ICN# on disk, how about changing it in memory? I can get its address in memory by giving the driver a csCode = 21 call, then simply change the data. This is what bootDiskIcon does.

Before I get to what you’re all waiting for, the source code, I’ll mention the difference between patches and INITs. A patch is a change to a piece of code, almost always one of the traps. An INIT resource is any piece of code that runs at startup time (typically in a file of type INIT, cdev, or rdev). An INIT frequently installs a patch, but it could do anything at all, like playing a tune or subverting a disk driver’s icon.

More ideological baggage: INITs should announce their presence. Paul Mercer has a good way to do this, called ShowINIT. I’m told the source code’s available on AppleLink. I’ve modified it to handle color icons, and compiled the whole thing as a separate resource, SHOW 0. bootDiskIcon calls this code. You’re welcome to use it in any non-commercial (free or shareware) programs -- just use ResEdit to paste SHOW 0 into your own INIT file. You may not use it in public domain programs. These are those without a copyright holder, and I don’t want my code in the public domain. Don’t make the mistake of calling your free program “public domain.” Once you do, you can’t get it back (despite what Adobe thinks).

We can almost get to the code, but you might be wondering how to test it. It’s real inconvenient to reboot, just to see if a change worked. Luckily, you don’t have to. Remember that an INIT is just a piece of code that happens to get executed at boot time. You can often execute the same code at any time, and instruct your development system to make an INIT resource when you’re finished debugging. In bootDiskIcon’s case, I simply executed it, juggled into the Finder layer, and verified that I’d chant the code. It starts out by calling my SHOW resource -- the parameters are reversed from the way they’re defined because my ShowICON is defined as a Pascal procedure. My sloppiness in not defining it as such in this C program probably works only because this is an INIT -- if I trash the stack, it doesn’t much matter, since I’ll be returning to INIT 31 very soon.

The real work begins with finding out the driver refNum and drive of the first mounted disk (now you know why it’s called bootDiskIcon -- I told you it was a quick hack). I then find the address of the driver’s ICN#, get an ICN# of my own choice, and overwrite the driver’s using BlockMove.

#include <deviceMgr.h>
#include <hfs.h>

#define NIL 0L

void  main(void);/* Always use prototypes! */

void main() {
 Ptr    icn;
 int    error;   /* Shouldn’t really be write-only  */
 HParamBlockRec  pb;
 cntrlParam cpb;
 Handle handle;

 /* Show icon on the bottom of the screen */
 handle = GetResource(‘SHOW’,0); /* Get handle to the PROC */
 if (handle == 0L) { /* Something’s wrong (couldn’t load) */
 SysBeep(32);    /* Let somebody know */
 return;/* Don’t try to call it! */
 }
 HLock(handle);  /* Hold down the PROC */
 (**(ProcPtr *)handle)(-1,128);  
 /* ShowICON() -- note reversed parameters */
 HUnlock(handle);/* Let it float in the heap again */

 /* Change the icon */
 pb.volumeParam.ioNamePtr = NIL;
 pb.volumeParam.ioVolIndex = 1;  /* First mounted volume */
 error = PBHGetVInfo(&pb,FALSE);
 cpb.ioRefNum = pb.volumeParam.ioVDRefNum;
 cpb.ioVRefNum = pb.volumeParam.ioVDrvInfo;  
 /* drive (ioDrvNum) */
 cpb.csCode = 21;
 error = PBControl(&cpb,FALSE);
 icn = *(Ptr *)(&cpb.csParam[0]);
 handle = GetResource(‘ICN#’,256);
 BlockMove(*handle,icn,256L);
}

Known Bugs

Actually, these are rumored bugs, because it works for me! I’m told it doesn’t work with Jasmine disks where the driver puts the SCSI ID inside the flower. It probably doesn’t work with a boot floppy, because the Finder normally special cases the disk icon. (Furthermore, Finder probably doesn’t consider floppies to be “foreign drives.”)

 

Community Search:
MacTech Search:

Software Updates via MacUpdate

Hopper Disassembler 4.3.10- - Binary dis...
Hopper Disassembler is a binary disassembler, decompiler, and debugger for 32- and 64-bit executables. It will let you disassemble any binary you want, and provide you all the information about its... Read more
Paparazzi! 1.0b7 - Make user-defined siz...
Paparazzi! is a small utility for OS X that makes screenshots of webpages. This very simple tool takes screenshots of websites which do not fit on one screen. You specify the desired width, minimal... Read more
Amadeus Pro 2.4.4 - Multitrack sound rec...
Amadeus Pro lets you use your Mac for any audio-related task, such as live audio recording, digitizing tapes and records, converting between a variety of sound formats, etc. Thanks to its outstanding... Read more
Google Chrome 63.0.3239.108 - Modern and...
Google Chrome is a Web browser by Google, created to be a modern platform for Web pages and applications. It utilizes very fast loading of Web pages and has a V8 engine, which is a custom built... Read more
Apple Configurator 2.6 - Configure and d...
Apple Configurator makes it easy to deploy iPad, iPhone, iPod touch, and Apple TV devices in your school or business. Use Apple Configurator to quickly configure large numbers of devices connected to... Read more
WhatRoute 2.0.26 - Geographically trace...
WhatRoute is designed to find the names of all the routers an IP packet passes through on its way from your Mac to a destination host. It also measures the round-trip time from your Mac to the router... Read more
Remotix 5.0.4 - Access all your computer...
Remotix is a fast and powerful application to easily access multiple Macs (and PCs) from your own Mac. Features Complete Apple Screen Sharing support - including Mac OS X login, clipboard... Read more
WhatRoute 2.0.26 - Geographically trace...
WhatRoute is designed to find the names of all the routers an IP packet passes through on its way from your Mac to a destination host. It also measures the round-trip time from your Mac to the router... Read more
Google Chrome 63.0.3239.108 - Modern and...
Google Chrome is a Web browser by Google, created to be a modern platform for Web pages and applications. It utilizes very fast loading of Web pages and has a V8 engine, which is a custom built... Read more
Paparazzi! 1.0b7 - Make user-defined siz...
Paparazzi! is a small utility for OS X that makes screenshots of webpages. This very simple tool takes screenshots of websites which do not fit on one screen. You specify the desired width, minimal... Read more

Latest Forum Discussions

See All

WWE Mayhem guide - beginner tips and tri...
WWE Mayhem brings all of the familiar faces from your favorite wrestling league to mobile in this exciting new fighting game. Build up a team of your favorite WWE superstars and fight your way to the championship title, or battle against your... | Read more »
The best new games we played this week -...
We've made it through another week, so let's treat ourselves to some of the best new games to launch in the past few days. It was another exciting week with some long-awaited indie games making their debut, and some big console titles making the... | Read more »
Match blocks to pull off dance moves in...
Ferdinand: Unstoppabull is a brand new match three puzzler based on the animated movie of (almost) the same name. As you can expect, you have to match blocks together to complete a bunch of puzzling levels and earn a high score. [Read more] | Read more »
Lineage 2: Revolution’s end of year upda...
Now available in 54 countries worldwide, Lineage 2: Revolution is continuing its global quest to be the most popular mobile MMORPG by launching a jam-packed end of year update. Complete with many subtle tweaks to help improve users’ online... | Read more »
The 5 best Star Wars games on iOS
The time has almost come.Star Wars: The Last Jedifinally hits theaters in the cinematic event that might be bigger than Christmas. To celebrate, we're taking a look at the best--and only the best--Star Warsmobile games to date. [Read more] | Read more »
Life Is Strange (Games)
Life Is Strange 1.1 Device: iOS Universal Category: Games Price: $2.99, Version: 1.1 (iTunes) Description: Life Is Strange is a five part episodic game that sets out to revolutionize story-based choice and consequence games by... | Read more »
Oddworld: New 'n' Tasty (Game...
Oddworld: New 'n' Tasty 1.0 Device: iOS Universal Category: Games Price: $7.99, Version: 1.0 (iTunes) Description: ** PLEASE NOTE: Requires 3.6GB free space to install. Runs at variable resolutions based on device capabilities.... | Read more »
Gorogoa (Games)
Gorogoa 1.0 Device: iOS Universal Category: Games Price: $4.99, Version: 1.0 (iTunes) Description: Gorogoa is an elegant evolution of the puzzle genre, told through a beautifully hand-drawn story designed and illustrated by Jason... | Read more »
Why Guns of Boom will be big for mobile...
Earlier this week, Game Insight, the minds that brought you Guns of Boom, revealed plans for an esports mode in the popular FPS title, with big implications for the game's future. Guns of Boom has been quite popular for some time now, so it's... | Read more »
The best mobile games to play on lazy ho...
With the holidays in full swing, there's hopefully going to be a lot of time off work lazing around the house. With all of that free time, it's a perfect opportunity to catch up on some mobile games that you might have missed out on earlier this... | Read more »

Price Scanner via MacPrices.net

The lowest prices on Apple 13″ MacBook Pros t...
Save $300-$300 on the purchase of a 2017 13″ MacBook Pro this weekend with Certified Refurbished models at Apple. In many cases, Apple’s refurbished prices are the lowest available for each model... Read more
Lowest prices of the Holiday season: 15″ Appl...
Save $360-$420 on the purchase of a 2017 15″ MacBook Pro with Certified Refurbished models at Apple. In many cases, Apple’s refurbished prices are the lowest available for each model from any... Read more
Apple discounts Beats products by up to 30% t...
Apple has Beats by Dr. Dre (BeatsX, Powerbeats3 Wireless, and Beats Solo3 Wireless) on sale for up to 30% off their retail price from now until December 26th: – BeatsX: Was $149.95, now $99 –... Read more
Updated Price Trackers: Macs, iPads, iPhones,...
Scan our Apple Price Trackers for the latest information on sales, bundles, and availability on systems from Apple’s authorized internet/catalog resellers. We update the trackers continuously: – 15″... Read more
How to preorder a new iMac Pro and pay zero s...
B&H Photo and Adorama are accepting preorders on multiple configurations of the new Apple iMac Pro. Both resellers charge sales tax for residents of NY & NJ only, and shipping is free.... Read more
Apple Macs back in stock at Amazon with model...
Amazon has MacBook Pros, MacBook Airs, MacBooks, and iMacs on sale for up to $200 off MSRP as part of their Holiday/Christmas sale. Shipping is free. Note that stock of some Macs may come and go (and... Read more
Apple offering free overnight delivery on all...
Apple is now offering free overnight delivery on all in stock products until 3pm local time on December 22nd. This includes new as well as refurbished computers. Click here for more information. Read more
Beats Holiday sale at B&H, headphones and...
B&H Photo has Beats by Dr. Dre headphones, earphones, and speakers on sale for up to $80 off MSRP as part of their Holiday sale. Expedited shipping is free, and B&H charges sales tax to NY... Read more
Holiday sale: Apple resellers offer 2017 15″...
MacMall has 15″ MacBook Pros on sale for $220-$300 off MSRP, each including free shipping: – 15″ 2.8GHz MacBook Pro Space Gray (MPTR2LL/A): $2179, $220 off MSRP – 15″ 2.8GHz MacBook Pro Silver (... Read more
Holiday sale: Apple resellers offer 13″ MacBo...
B&H Photo has 13″ MacBook Pros on sale for up to $150 off MSRP. Shipping is free, and B&H charges sales tax for NY & NJ residents only: – 13-inch 2.3GHz/128GB Space Gray MacBook Pro (... Read more

Jobs Board

*Apple* Retail - Multiple Positions - Apple,...
Job Description: Sales Specialist - Retail Customer Service and Sales Transform Apple Store visitors into loyal Apple customers. When customers enter the store, Read more
*Apple* Retail - Multiple Positions - Apple,...
Job Description:SalesSpecialist - Retail Customer Service and SalesTransform Apple Store visitors into loyal Apple customers. When customers enter the store, Read more
*Apple* Retail - Multiple Positions - Apple,...
Job Description: Sales Specialist - Retail Customer Service and Sales Transform Apple Store visitors into loyal Apple customers. When customers enter the store, Read more
*Apple* Retail - Multiple Positions - Apple,...
Job Description:SalesSpecialist - Retail Customer Service and SalesTransform Apple Store visitors into loyal Apple customers. When customers enter the store, Read more
*Apple* Retail - Multiple Positions - Apple,...
Job Description: Sales Specialist - Retail Customer Service and Sales Transform Apple Store visitors into loyal Apple customers. When customers enter the store, Read more
All contents are Copyright 1984-2011 by Xplain Corporation. All rights reserved. Theme designed by Icreon.