8.0-RELEASE-i386-memstick fixit - No USB devices found!

Ian Smith smithi at nimnet.asn.au
Thu Dec 10 10:18:53 UTC 2009


On Sat, 5 Dec 2009, Randi Harper wrote:
 > On Sat, Dec 5, 2009 at 4:01 AM, Ian Smith <smithi at nimnet.asn.au> wrote:
 > > In freebsd-questions Digest, Vol 286, Issue 12, Message 7
 > > On Fri, 27 Nov 2009 06:51:50 -0800 Randi Harper <randi at freebsd.org> wrote:
 > >  > On Fri, Nov 27, 2009 at 5:00 AM, Derek (freebsd lists) <482254ac at razorfever.net> wrote:
[..]
 > > I made the memstick.img by dd as per the release page on my Thinkpad
 > > T23.  It only sports USB 1.0 ports, and while I was confident of the dd
 > > (which took ~25m at ~600kB/s), I didn't really expect a 2002 laptop to
 > > boot from the image, but on seeing the USB stick show up in its BIOS and
 > > promoting it in the disk boot order, it did!  Never underestimate IBM ..
[..]
 > > So .. booted into sysinstall, fdisk and label ad0s4, leave boot0 as was,
 > > committed that much after two earlier attempts failed due to the below,
 > > quit to reboot, checked the labelling, redid the mount points, all ok.
 > >
 > > Picked pretty much all distributions from custom install, then of course
 > > had to select media.  Picked USB - and got about what Derek did, no USB
 > > disk found.
 > >
 > > Very long story short: googled for ages and found a forum thread about
 > > this very problem, in which someone suggested Options / Rescan Devices
 > > then trying again.  The OP there said it didn't work for him, but it
 > > sure did for me!  After knowing that, the install went pretty smoothly,
 > > modulo not getting fc-10 to install by FTP, but that's another issue..
 > >
 > > And just now, prompted by this thread I tried selecting Fixit, to again
 > > get what Derek did.  And again, Options / Rescan Devices fixed it for
 > > me.  Maybe it will for Derek and/or maybe provide another clue?  Maybe
 > > sysinstall could try a device rescan itself in that circumstance?
 > 
 > This is a known issue. It would be possible to write in a hack to fix
 > this problem that would be fairly quick to implement, but sysinstall
 > already has one too many bandaids in place. I'd rather take a little
 > bit of extra time and fix the underlying problem, especially since
 > there is this workaround (forcing a device rescan) that seems to work
 > for users in the meanwhile.

At best it's an 'unknown known' :)  Except for this present thread, my 
'googling for ages' found nothing in FreeBSD lists about it.  I was so 
close to giving up until I could go somewhere to burn a DVD, by then.

I appreciate your disinclination to extend that message in sysinstall, 
it's been "about to die" for so long it's no longer funny, still it 
would have saved me half a day, and I'm sure I won't be the last person 
to run into this.  I guess I should file a PR with a patch ..

 > sysinstall was written back in the good 'ol days of pre-devfs and
 > hasn't been updated much since. When it first runs, it does a device
 > scan - that is, there's this really ugly data structure of all
 > possible devices and a description/limit for each. So, just for
 > example (and I'm not checking the code, so this value is probably
 > wrong), say there's an entry for 'fxp' that is a type network with a
 > limit of 16 devices - it's going to poke the system looking for fxp0,
 > fxp1, ..., fxp15. It's doing this for every single network card, all
 > possible disk devices, everything. Back in the day when computers were
 > slower, this process could take a while, so it only happened once
 > unless the user selected it again.

But now, a rescan on my T23 was quite fast, and it's only a P3 1133MHz.

 > Needless to say, this is extremely inefficient (sysinstall code has to
 > be changed any time a new driver is added, too!) and there's a lot of
 > better ways to do this. It's very easy to pull a list of network
 > cards, disks, etc, but the work in moving away from that ugly data
 > structure is no small job. Right now, much of my time is being taken
 > up in trying to get gpt support into sysinstall, but getting rid of
 > that data structure is high in my priority list, especially since
 > there's a workaround. Old/cheap USB flash sticks seem to be the main
 > offender, as they are slow to be recognized/probed, and sysinstall has
 > already finished it's device scan by then.

Point taken, but an unknown workaround is no use to the newbie installer 
(see my prior whinge to Manolis re the X installation menu going away)

Yes, I was using an older 1GB Shintaro stick, the only one on hand, on a 
machine using USB 1.0 only, but I doubt I'll be the only one; sysinstall 
has always striven to work with other than just top-range newer kit.  I 
do know how hard it is for developers to remember what mortals don't 
know, or to imagine why folks might not be running more recent gear :)

 > > While I'm at it .. selecting 'Holographic Shell', while in that state at
 > > least, brings up a shell that (perhaps due to stick not being mounted?)
 > > has no ls command, making navigation difficult :)  pwd works, set works,
 > > but no ls.  Later (from debug msgs on vty1) I saw that I'd been perhaps
 > > in /stand and only much later found that find worked and served as ls ..
 > 
 > This is normal. That's running off of the memory disk. echo * also
 > works to list files. The memory disk needs to stay fairly small in
 > size, so it has only a few programs, mostly stuff that is used by
 > sysinstall.

echo *, now why didn't I think of that :)

Yeah, I spent a few hours today browsing the src/release stuff.  The 
annotated Makefile alone is a potted history of FreeBSD, and seeing the 
strange mix of floppies through CDs to DVD is interesting, especially 
when the old so constrains the new with perhaps excessive minimalism.

 > > One more thing, while I remember .. seeing the USB stick is here ad0a,
 > > isn't that the old 'dangerously dedicated mode' now dropped from 8.0?
 > 
 > Well... yes. But this works. DD mode still works sometimes, but it's
 > easier to say "not supported" than "only in these circumstances".
 > FWIW, I don't expect DD mode to be gone forever. There were changes
 > made outside of sysinstall that aren't compatible with the way that
 > sysinstall (specifically, libdisk) did things. I think. It's
 > complicated, not something I'm entirely sure about, and  I
 > unfortunately can't do anything about other than moving away from
 > libdisk to libgeom. But this won't fix prior installations. I'm hoping
 > that those working on geom can come up with a solution for existing DD
 > installs.

Fair enough, it's a big shift.  I appreciate your detailed explanations.

 > > And to be a real pest with questions, where in CVS do I find the script
 > > or whatever makes memstick.img in the first place?
 > 
 > It's part of the make release process. You really don't want to touch
 > that. I don't even want to touch that. When I'm testing out
 > sysinstall, I take an existing memstick and modify it as opposed to
 > building an entirely new one.

I don't want to touch that, not at least till (if ever) I know exactly 
what's going on there - but I do want to know how such images are made.

Can you share what arguments to make release are used, or what other 
steps are needed to duplicate it?  I'm wondering about a 4GB image say,
but perhaps this would be a question better posed in -stable?

cheers, Ian


More information about the freebsd-questions mailing list