1995-05-27 10:39:04 +00:00
|
|
|
/*
|
|
|
|
* The new sysinstall program.
|
|
|
|
*
|
|
|
|
* This is probably the last attempt in the `sysinstall' line, the next
|
|
|
|
* generation being slated to essentially a complete rewrite.
|
|
|
|
*
|
1997-04-03 13:44:59 +00:00
|
|
|
* $Id: cdrom.c,v 1.38 1997/02/22 14:11:12 peter Exp $
|
1995-05-27 10:39:04 +00:00
|
|
|
*
|
|
|
|
* Copyright (c) 1995
|
|
|
|
* Jordan Hubbard. All rights reserved.
|
|
|
|
* Copyright (c) 1995
|
|
|
|
* Gary J Palmer. All rights reserved.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
1995-05-30 08:29:07 +00:00
|
|
|
* notice, this list of conditions and the following disclaimer,
|
|
|
|
* verbatim and that no modifications are made prior to this
|
1995-05-27 10:39:04 +00:00
|
|
|
* point in the file.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY JORDAN HUBBARD ``AS IS'' AND
|
|
|
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL JORDAN HUBBARD OR HIS PETS BE LIABLE
|
|
|
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
* OR SERVICES; LOSS OF USE, DATA, LIFE OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
* SUCH DAMAGE.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
1995-05-28 03:05:06 +00:00
|
|
|
/* These routines deal with getting things off of CDROM media */
|
1995-05-27 10:39:04 +00:00
|
|
|
|
|
|
|
#include "sysinstall.h"
|
|
|
|
#include <sys/stat.h>
|
|
|
|
#include <sys/errno.h>
|
|
|
|
#include <sys/param.h>
|
|
|
|
#include <sys/wait.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
#include <grp.h>
|
1995-05-27 23:39:35 +00:00
|
|
|
#include <fcntl.h>
|
1995-05-27 10:39:04 +00:00
|
|
|
|
|
|
|
#define CD9660
|
|
|
|
#include <sys/mount.h>
|
1997-04-03 13:44:59 +00:00
|
|
|
#include <isofs/cd9660/cd9660_mount.h>
|
1995-05-27 10:39:04 +00:00
|
|
|
#undef CD9660
|
|
|
|
|
1997-01-22 00:15:51 +00:00
|
|
|
static Boolean cdromMounted;
|
1995-05-27 10:39:04 +00:00
|
|
|
|
|
|
|
Boolean
|
|
|
|
mediaInitCDROM(Device *dev)
|
|
|
|
{
|
|
|
|
struct iso_args args;
|
1996-06-11 05:06:32 +00:00
|
|
|
Attribs *cd_attr;
|
|
|
|
char *cp;
|
1997-01-06 11:10:25 +00:00
|
|
|
Boolean readInfo = TRUE;
|
OK, I've got two ideas to file in the "really seemed like a good idea
at the time, but on further reflection..." bucket with these changes.
1. Checking the media before frobbing the disks was a fine idea, and
I wish it could have worked, but that leads to a rather difficult
situation when you need to mount the media someplace and you're about
to:
a) Chroot away from your present root.
b) Newfs the root to be.
You're basically screwed since there's no place to stick the mount
point where it will be found following the newfs/chroot (and eliminating
the chroot in favor of just using the "root bias" feature would work
great for the distributions but not the pkg_add calls done by the
package installer).
2. Automatic timeout handling. I don't know why, but alarm() frequently
returns no residual even when the alarm didn't go off, which defies
the man page but hey, since when was that so unusual? Take out timeouts
but retain the code which temporarily replaces the SIGINT handler in
favor of a more media-specific handler. This way, at least, if it's hanging
you can at least whap it. I think the timeout code would have been losing
over *really slow* links anyway, so it's probably best that it go.
This should fix NFS, tape & CDROM installs again (serves me right for getting
complacent and using just the FTP installs in my testing).
1997-01-24 19:24:51 +00:00
|
|
|
char *mountpoint = "/dist";
|
1995-05-27 10:39:04 +00:00
|
|
|
|
1997-01-22 00:15:51 +00:00
|
|
|
if (cdromMounted)
|
1995-05-27 10:39:04 +00:00
|
|
|
return TRUE;
|
|
|
|
|
1995-05-29 11:01:42 +00:00
|
|
|
bzero(&args, sizeof(args));
|
1995-05-27 10:39:04 +00:00
|
|
|
args.fspec = dev->devname;
|
|
|
|
args.flags = 0;
|
|
|
|
|
1996-12-12 08:33:38 +00:00
|
|
|
cd_attr = alloca(sizeof(Attribs) * MAX_ATTRIBS);
|
1996-06-11 05:06:32 +00:00
|
|
|
cp = NULL;
|
1997-01-22 00:15:51 +00:00
|
|
|
|
|
|
|
Mkdir(mountpoint);
|
|
|
|
|
|
|
|
if (mount(MOUNT_CD9660, mountpoint, MNT_RDONLY, (caddr_t) &args) == -1) {
|
|
|
|
if (errno == EINVAL) {
|
|
|
|
msgConfirm("The CD in your drive looks more like an Audio CD than a FreeBSD release.");
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
else if (errno != EBUSY) {
|
|
|
|
msgConfirm("Error mounting %s on %s: %s (%u)", dev->devname, mountpoint, strerror(errno), errno);
|
|
|
|
return FALSE;
|
1995-05-27 10:39:04 +00:00
|
|
|
}
|
1997-01-22 00:15:51 +00:00
|
|
|
cdromMounted = TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!file_readable(string_concat(mountpoint, "/cdrom.inf"))) {
|
|
|
|
if (msgYesNo("Warning: The CD currently in the drive is either not a FreeBSD\n"
|
|
|
|
"CD or it is an older (pre 2.1.5) FreeBSD CD which does not\n"
|
|
|
|
"have a version number on it. Do you wish to use this CD anyway?") != 0) {
|
|
|
|
unmount(mountpoint, MNT_FORCE);
|
|
|
|
return FALSE;
|
1996-06-11 05:06:32 +00:00
|
|
|
}
|
1997-01-22 00:15:51 +00:00
|
|
|
else
|
|
|
|
readInfo = FALSE;
|
1995-05-27 10:39:04 +00:00
|
|
|
}
|
1997-01-22 00:15:51 +00:00
|
|
|
|
|
|
|
if (readInfo &&
|
|
|
|
(DITEM_STATUS(attr_parse_file(cd_attr, string_concat(mountpoint, "/cdrom.inf"))) == DITEM_FAILURE ||
|
1997-01-27 09:51:56 +00:00
|
|
|
!(cp = attr_match(cd_attr, "CD_VERSION")) || (strcmp(cp, variable_get(VAR_RELNAME)) && strcmp("none", variable_get(VAR_RELNAME))))) {
|
1996-06-11 05:06:32 +00:00
|
|
|
if (!cp)
|
1997-01-22 00:15:51 +00:00
|
|
|
msgConfirm("Unable to find a %s/cdrom.inf file.\n"
|
1996-06-11 05:06:32 +00:00
|
|
|
"Either this is not a FreeBSD CDROM, there is a problem with\n"
|
|
|
|
"the CDROM driver or something is wrong with your hardware.\n"
|
|
|
|
"Please fix this problem (check the console logs on VTY2) and\n"
|
1997-01-22 00:15:51 +00:00
|
|
|
"try again.", mountpoint);
|
1996-06-11 05:06:32 +00:00
|
|
|
else
|
1996-10-10 09:22:37 +00:00
|
|
|
msgConfirm("Warning: The version of the FreeBSD CD currently in the drive\n"
|
1997-01-06 11:10:25 +00:00
|
|
|
"(%s) does not match the version of the boot floppy\n"
|
1996-10-10 09:22:37 +00:00
|
|
|
"(%s).\n\n"
|
1997-01-06 11:10:25 +00:00
|
|
|
"If this is intentional, to avoid this message in the future\n"
|
|
|
|
"please visit the Options editor to set the boot floppy version\n"
|
|
|
|
"string to match that of the CD before selecting it as your\n"
|
|
|
|
"installation media.", cp, variable_get(VAR_RELNAME));
|
|
|
|
|
|
|
|
if (msgYesNo("Would you like to try and use this CDROM anyway?") != 0) {
|
1997-01-22 00:15:51 +00:00
|
|
|
unmount(mountpoint, MNT_FORCE);
|
|
|
|
cdromMounted = FALSE;
|
1997-01-06 11:10:25 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
1996-06-11 05:06:32 +00:00
|
|
|
}
|
1997-01-22 00:15:51 +00:00
|
|
|
msgDebug("Mounted FreeBSD CDROM from device %s\n", dev->devname);
|
1995-05-27 10:39:04 +00:00
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
1996-12-11 09:35:06 +00:00
|
|
|
FILE *
|
1996-03-02 07:31:58 +00:00
|
|
|
mediaGetCDROM(Device *dev, char *file, Boolean probe)
|
1995-05-27 10:39:04 +00:00
|
|
|
{
|
1995-12-07 10:34:59 +00:00
|
|
|
char buf[PATH_MAX];
|
1995-05-27 10:39:04 +00:00
|
|
|
|
1996-08-23 07:56:06 +00:00
|
|
|
if (isDebug())
|
|
|
|
msgDebug("Request for %s from CDROM\n", file);
|
1997-01-22 00:15:51 +00:00
|
|
|
snprintf(buf, PATH_MAX, "/dist/%s", file);
|
1995-12-07 10:34:59 +00:00
|
|
|
if (file_readable(buf))
|
1996-12-11 09:35:06 +00:00
|
|
|
return fopen(buf, "r");
|
1997-01-22 00:15:51 +00:00
|
|
|
snprintf(buf, PATH_MAX, "/dist/dists/%s", file);
|
1995-12-07 10:34:59 +00:00
|
|
|
if (file_readable(buf))
|
1996-12-11 09:35:06 +00:00
|
|
|
return fopen(buf, "r");
|
1997-01-22 00:15:51 +00:00
|
|
|
snprintf(buf, PATH_MAX, "/dist/%s/%s", variable_get(VAR_RELNAME), file);
|
1995-12-07 10:34:59 +00:00
|
|
|
if (file_readable(buf))
|
1996-12-11 09:35:06 +00:00
|
|
|
return fopen(buf, "r");
|
1997-01-22 00:15:51 +00:00
|
|
|
snprintf(buf, PATH_MAX, "/dist/%s/dists/%s", variable_get(VAR_RELNAME), file);
|
1996-12-11 09:35:06 +00:00
|
|
|
return fopen(buf, "r");
|
1995-05-27 10:39:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
mediaShutdownCDROM(Device *dev)
|
|
|
|
{
|
OK, I've got two ideas to file in the "really seemed like a good idea
at the time, but on further reflection..." bucket with these changes.
1. Checking the media before frobbing the disks was a fine idea, and
I wish it could have worked, but that leads to a rather difficult
situation when you need to mount the media someplace and you're about
to:
a) Chroot away from your present root.
b) Newfs the root to be.
You're basically screwed since there's no place to stick the mount
point where it will be found following the newfs/chroot (and eliminating
the chroot in favor of just using the "root bias" feature would work
great for the distributions but not the pkg_add calls done by the
package installer).
2. Automatic timeout handling. I don't know why, but alarm() frequently
returns no residual even when the alarm didn't go off, which defies
the man page but hey, since when was that so unusual? Take out timeouts
but retain the code which temporarily replaces the SIGINT handler in
favor of a more media-specific handler. This way, at least, if it's hanging
you can at least whap it. I think the timeout code would have been losing
over *really slow* links anyway, so it's probably best that it go.
This should fix NFS, tape & CDROM installs again (serves me right for getting
complacent and using just the FTP installs in my testing).
1997-01-24 19:24:51 +00:00
|
|
|
char *mountpoint = "/dist";
|
1997-01-22 00:15:51 +00:00
|
|
|
|
|
|
|
if (!cdromMounted)
|
1995-05-27 10:39:04 +00:00
|
|
|
return;
|
1997-01-22 00:15:51 +00:00
|
|
|
msgDebug("Unmounting %s from %s\n", dev->devname, mountpoint);
|
|
|
|
if (unmount(mountpoint, MNT_FORCE) != 0)
|
|
|
|
msgConfirm("Could not unmount the CDROM from %s: %s", mountpoint, strerror(errno));
|
1996-06-08 07:02:21 +00:00
|
|
|
else {
|
1997-01-06 11:10:25 +00:00
|
|
|
msgDebug("Unmount of CDROM successful\n");
|
1997-01-22 00:15:51 +00:00
|
|
|
cdromMounted = FALSE;
|
1996-06-08 07:02:21 +00:00
|
|
|
}
|
1995-05-27 10:39:04 +00:00
|
|
|
}
|