NetBSD/distrib/utils/sysinst/upgrade.c
abs eff3a12f1c defs.h:
- Re-order the md_*() definitions so they are in the order called
- Add some comments
- Remove obsolete md_set_no_x() definition
- Remove md_copy_filesystem()
- #if defined(DEBUG) declare backtowin(void) to avoid scattering
  externs in various md .c files

mbr.[ch]:
- Add a set_bios_geom_with_mbr_guess() which can be called by all
  the non x86 ports rather than copying the same code into arc,
  bebox, cobalt, evbmips, evbppc, hpcarm, hpcmips, landisk, ofppc,
  prep, sandpoint, and zaurus md.c

install.c:
- Remove now unnecessary call to md_copy_filesystem()

upgrade.c:
- Move move_aout_libs() here, and put under #ifdef AOUT2ELF
- Rather than having *every* md_update call wrefresh(curscr),
  wmove(stdscr, 0, 0), wclear(stdscr), and wrefresh(stdscr),
  move them here

arch/acorn26/md.c:
- Just include arch/acorn32/md.c, but add a note there warning
  about this, and while here add a note to i386/md.c that it
  is included by amd64

arch/*/md.c:
- By all means "Vive la difference", but we have 38 pairs of md.[ch],
  and they could not even agree on the order in which to list the
  md hooks, let alone formatting. Sort the md hooks to match the
  (now sane) order in def.sh, and try to normalise the formatting
- Also copy across some function level comments everywhere
- Ensure functions only used inside each md.c are defined as static
- Remove some now unused functions
- Some files had enable_rc_conf in #ifdef DEBUG. Add this to all
- bebox, evbppc and sandpoint were still playing broken games with
  copying the booted ramdisk to the target disk, the primary result
  of which was just to slow things down and ensure the target system
  lost the .profile extracted from the sets. Just kill this.
- For some ports md_update() called endwin(), and in others not.
  Take a cure from i386/amd64 and a few other more active ports,
  and update everything to match (no endwin())
- In a couple of cases correct port names in comments
- ANSIfy some lingering old style functions
- Consistently use "return 0;" rather than "return (0);"

More of the mbr code should be abstracted, along with the
get_ramsize() / set_swap() logic, but this is (more than)
enough for one day...

sysinst built for all ports but only runtime tested on amd64 & i386
2009-09-19 14:57:27 +00:00

182 lines
4.3 KiB
C

/* $NetBSD: upgrade.c,v 1.50 2009/09/19 14:57:27 abs Exp $ */
/*
* Copyright 1997 Piermont Information Systems Inc.
* All rights reserved.
*
* Written by Philip A. Nelson for Piermont Information Systems Inc.
*
* 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
* notice, this list of conditions and the following disclaimer.
* 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.
* 3. All advertising materials mentioning features or use of this software
* must display the following acknowledgement:
* This product includes software developed for the NetBSD Project by
* Piermont Information Systems Inc.
* 4. The name of Piermont Information Systems Inc. may not be used to endorse
* or promote products derived from this software without specific prior
* written permission.
*
* THIS SOFTWARE IS PROVIDED BY PIERMONT INFORMATION SYSTEMS INC. ``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 PIERMONT INFORMATION SYSTEMS INC. 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, 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.
*
*/
/* upgrade.c -- upgrade an installation. */
#include <stdio.h>
#include <curses.h>
#include <errno.h>
#include "defs.h"
#include "msg_defs.h"
#include "menu_defs.h"
/*
* local prototypes
*/
static int save_X(void);
static int merge_X(void);
/*
* Do the system upgrade.
*/
void
do_upgrade(void)
{
msg_display(MSG_upgradeusure);
process_menu(MENU_noyes, NULL);
if (!yesno)
return;
get_ramsize();
if (find_disks(msg_string(MSG_upgrade)) < 0)
return;
if (md_pre_update() < 0)
return;
process_menu(MENU_distset, NULL);
if (mount_disks() != 0)
return;
/*
* Save X symlink, ...
*/
if (save_X())
return;
#ifdef AOUT2ELF
move_aout_libs();
#endif
/* Do any md updating of the file systems ... e.g. bootblocks,
copy file systems ... */
if (!md_update())
return;
wrefresh(curscr);
wmove(stdscr, 0, 0);
wclear(stdscr);
wrefresh(stdscr);
/* Done with disks. Ready to get and unpack tarballs. */
if (get_and_unpack_sets(1, MSG_disksetupdoneupdate,
MSG_upgrcomplete, MSG_abortupgr) != 0)
return;
if (!md_post_extract() == 0)
return;
merge_X();
sanity_check();
}
/*
* Save X symlink to X.old so it can be recovered later
*/
static int
save_X(void)
{
/* Only care for X if it's a symlink */
if (target_symlink_exists_p("/usr/X11R6/bin/X")) {
if (target_symlink_exists_p("/usr/X11R6/bin/X.old")) {
msg_display(MSG_X_oldexists);
process_menu(MENU_ok, NULL);
return EEXIST;
}
#ifdef DEBUG
printf("saving /usr/X11R6/bin/X as .../X.old ...");
#endif
/* Move target .../X to .../X.old. Abort on error. */
mv_within_target_or_die("/usr/X11R6/bin/X",
"/usr/X11R6/bin/X.old");
}
return 0;
}
/*
* Merge back saved target X files after unpacking the new
* sets has completed.
*/
static int
merge_X(void)
{
if (target_symlink_exists_p("/usr/X11R6/bin/X.old")) {
/* Only move back X if it's a symlink - we don't want
* to restore old binaries */
mv_within_target_or_die("/usr/X11R6/bin/X.old",
"/usr/X11R6/bin/X");
}
return 0;
}
/*
* Unpacks sets, clobbering existing contents.
*/
void
do_reinstall_sets(void)
{
unwind_mounts();
msg_display(MSG_reinstallusure);
process_menu(MENU_noyes, NULL);
if (!yesno)
return;
if (find_disks(msg_string(MSG_reinstall)) < 0)
return;
process_menu(MENU_distset, NULL);
if (mount_disks() != 0)
return;
/* Unpack the distribution. */
if (get_and_unpack_sets(0, NULL, MSG_unpackcomplete, MSG_abortunpack) != 0)
return;
sanity_check();
}