summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorOlivier Blin <oblin@mandriva.org>2004-06-21 06:48:40 +0000
committerOlivier Blin <oblin@mandriva.org>2004-06-21 06:48:40 +0000
commitf6efe04f7b663a108babc326e280966de1192265 (patch)
treeecaa8bedd6043a58ef0b643fac0d701b90274074
parenta62a05d73eddd30e01a3fa2b11e06a4e84af20e1 (diff)
downloaddrakx-backup-do-not-use-f6efe04f7b663a108babc326e280966de1192265.tar
drakx-backup-do-not-use-f6efe04f7b663a108babc326e280966de1192265.tar.gz
drakx-backup-do-not-use-f6efe04f7b663a108babc326e280966de1192265.tar.bz2
drakx-backup-do-not-use-f6efe04f7b663a108babc326e280966de1192265.tar.xz
drakx-backup-do-not-use-f6efe04f7b663a108babc326e280966de1192265.zip
allow to use ISO images in NFS install
-rw-r--r--mdk-stage1/Makefile2
-rw-r--r--mdk-stage1/network.c29
2 files changed, 7 insertions, 24 deletions
diff --git a/mdk-stage1/Makefile b/mdk-stage1/Makefile
index f40e0ef1d..c5e98989b 100644
--- a/mdk-stage1/Makefile
+++ b/mdk-stage1/Makefile
@@ -126,7 +126,7 @@ endif
STAGE1SRC = stage1.c log.c tools.c modules.c probing.c mount.c automatic.c frontend-common.c
CDROMSRC = cdrom.c $(MOVE_ADDSRC)
DISKSRC = disk.c directory.c lomount.c
-NETWORKSRC = network.c nfsmount.c dhcp.c url.c dns.c adsl.c $(MOVE_ADDSRC)
+NETWORKSRC = network.c nfsmount.c dhcp.c url.c dns.c adsl.c directory.c lomount.c $(MOVE_ADDSRC)
ALLSRC = $(INITSRC) $(STAGE1SRC) $(CDROMSRC) $(DISKSRC) $(NETWORKSRC)
diff --git a/mdk-stage1/network.c b/mdk-stage1/network.c
index d71cceb87..937b89139 100644
--- a/mdk-stage1/network.c
+++ b/mdk-stage1/network.c
@@ -45,6 +45,7 @@
#include "dns.h"
#include "network.h"
+#include "directory.h"
/* include it after config-stage1.h so that _GNU_SOURCE is defined and strndup is available */
#include <string.h>
@@ -850,6 +851,7 @@ enum return_type nfs_prepare(void)
char * questions[] = { "NFS server name", DISTRIB_NAME " directory", NULL };
char * questions_auto[] = { "server", "directory", NULL };
static char ** answers = NULL;
+ char * nfs_own_mount = SLASH_LOCATION "/tmp/nfsimage";
char * nfsmount_location;
enum return_type results = intf_select_and_up(NULL, NULL);
@@ -870,37 +872,18 @@ enum return_type nfs_prepare(void)
strcat(nfsmount_location, ":");
strcat(nfsmount_location, answers[1]);
- if (my_mount(nfsmount_location, IMAGE_LOCATION, "nfs", 0) == -1) {
+ if (my_mount(nfsmount_location, nfs_own_mount, "nfs", 0) == -1) {
stg1_error_message("I can't mount the directory from the NFS server.");
results = RETURN_BACK;
continue;
}
-#ifdef MANDRAKE_MOVE
- if (access(IMAGE_LOCATION "/live_tree/etc/fstab", R_OK) && access(IMAGE_LOCATION "/live_tree.clp", R_OK)) {
-#else
- if (access(IMAGE_LOCATION LIVE_LOCATION, R_OK)) {
-#endif
- stg1_error_message("That NFS volume does not seem to contain the " DISTRIB_NAME " Distribution.");
- umount(IMAGE_LOCATION);
- results = RETURN_BACK;
- }
+ results = try_with_directory(nfs_own_mount, "nfs", "nfs-iso");
+ if (results == RETURN_BACK)
+ umount(nfs_own_mount);
}
while (results == RETURN_BACK);
- log_message("found the " DISTRIB_NAME " Installation, good news!");
-
- if (IS_SPECIAL_STAGE2) {
- if (load_ramdisk() != RETURN_OK) {
- stg1_error_message("Could not load program into memory.");
- return nfs_prepare();
- }
- }
-
- if (IS_RESCUE)
- umount(IMAGE_LOCATION);
-
- add_to_env("METHOD", "nfs");
return RETURN_OK;
}