NetBSD/usr.sbin/sysinst/defs.h
christos e47dca206e Don't use asctime(localtime(time_t *)) because this is really ctime(time_t *)
and not checking the result of localtime can lead to tears.
Add a safectime() that always returns a good string, and add some debugging
so that we can see if there is indeed something wrong in the new libc time
code.
2014-10-14 16:35:20 +00:00

630 lines
19 KiB
C

/* $NetBSD: defs.h,v 1.5 2014/10/14 16:35:20 christos 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. 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.
*
*/
#ifndef _DEFS_H_
#define _DEFS_H_
/* defs.h -- definitions for use in the sysinst program. */
/* System includes needed for this. */
#include <sys/queue.h>
#include <sys/types.h>
#include <sys/disklabel.h>
#include <sys/disk.h>
const char *getfslabelname(uint8_t);
static inline void *
deconst(const void *p)
{
return (char *)0 + ((const char *)p - (const char *)0);
}
#include "msg_defs.h"
#include "menu_defs.h"
#define min(a,b) ((a) < (b) ? (a) : (b))
#define max(a,b) ((a) > (b) ? (a) : (b))
/* constants */
#define MEG (1024 * 1024)
#define STRSIZE 255
#define SSTRSIZE 30
/* For run.c: collect() */
#define T_FILE 0
#define T_OUTPUT 1
/* Some install status/response values */
#define SET_OK 0 /* Set extracted */
#define SET_RETRY 1 /* Retry */
#define SET_SKIP 2 /* Skip this set */
#define SET_SKIP_GROUP 3 /* Skip this set and rest of group */
#define SET_ABANDON 4 /* Abandon installation */
#define SET_CONTINUE 5 /* Continue (copy from floppy loop) */
/* run_prog flags */
#define RUN_DISPLAY 0x0001 /* Display program output */
#define RUN_FATAL 0x0002 /* errors are fatal */
#define RUN_CHROOT 0x0004 /* chroot to target disk */
#define RUN_FULLSCREEN 0x0008 /* fullscreen (use with RUN_DISPLAY) */
#define RUN_SILENT 0x0010 /* Do not show output */
#define RUN_ERROR_OK 0x0040 /* Don't wait for error confirmation */
#define RUN_PROGRESS 0x0080 /* Output is just progess test */
#define RUN_NO_CLEAR 0x0100 /* Leave program output after error */
#define RUN_XFER_DIR 0x0200 /* cd to xfer_dir in child */
/* for bsddisklabel.c */
enum { LY_SETNEW, LY_NEWRAID, LY_NEWCGD, LY_NEWLVM, LY_USEEXIST };
/* Installation sets */
enum {
SET_NONE,
SET_KERNEL_FIRST,
SET_KERNEL_1, /* Usually GENERIC */
SET_KERNEL_2, /* MD kernel... */
SET_KERNEL_3, /* MD kernel... */
SET_KERNEL_4, /* MD kernel... */
SET_KERNEL_5, /* MD kernel... */
SET_KERNEL_6, /* MD kernel... */
SET_KERNEL_7, /* MD kernel... */
SET_KERNEL_8, /* MD kernel... */
SET_KERNEL_9, /* MD kernel... */
SET_KERNEL_LAST, /* allow 9 kernels */
/* System sets */
SET_BASE, /* base */
SET_ETC, /* /etc */
SET_COMPILER, /* compiler tools */
SET_GAMES, /* text games */
SET_MAN_PAGES, /* online manual pages */
SET_MISC, /* miscellaneuous */
SET_MODULES, /* kernel modules */
SET_TESTS, /* tests */
SET_TEXT_TOOLS, /* text processing tools */
/* X11 sets */
SET_X11_FIRST,
SET_X11_BASE, /* X11 base and clients */
SET_X11_FONTS, /* X11 fonts */
SET_X11_SERVERS, /* X11 servers */
SET_X11_PROG, /* X11 programming */
SET_X11_ETC, /* X11 config */
SET_X11_LAST,
/* Machine dependent sets */
SET_MD_1, /* Machine dependent set */
SET_MD_2, /* Machine dependent set */
SET_MD_3, /* Machine dependent set */
SET_MD_4, /* Machine dependent set */
/* Source sets */
SET_SYSSRC,
SET_SRC,
SET_SHARESRC,
SET_GNUSRC,
SET_XSRC,
/* Debug sets */
SET_DEBUG,
SET_X11_DEBUG,
SET_LAST,
SET_GROUP, /* Start of submenu */
SET_GROUP_END, /* End of submenu */
SET_PKGSRC, /* pkgsrc, not counted as regular set */
};
/* Initialisers to select sets */
/* All kernels */
#define SET_KERNEL SET_KERNEL_1, SET_KERNEL_2, SET_KERNEL_3, SET_KERNEL_4, \
SET_KERNEL_5, SET_KERNEL_6, SET_KERNEL_7, SET_KERNEL_8
/* Core system sets */
#define SET_CORE SET_MODULES, SET_BASE, SET_ETC
/* All system sets */
#define SET_SYSTEM SET_CORE, SET_COMPILER, SET_GAMES, \
SET_MAN_PAGES, SET_MISC, SET_TESTS, SET_TEXT_TOOLS
/* All X11 sets */
#define SET_X11_NOSERVERS SET_X11_BASE, SET_X11_FONTS, SET_X11_PROG, SET_X11_ETC
#define SET_X11 SET_X11_NOSERVERS, SET_X11_SERVERS
/* All machine dependent sets */
#define SET_MD SET_MD_1, SET_MD_2, SET_MD_3, SET_MD_4
/* All source sets */
#define SET_SOURCE SET_SYSSRC, SET_SRC, SET_SHARESRC, SET_GNUSRC, SET_XSRC
/* All debug sets */
#define SET_DEBUGGING SET_DEBUG, SET_X11_DEBUG
/* Set list flags */
#define SFLAG_MINIMAL 1
#define SFLAG_NOX 2
/* Macros */
#define nelem(x) (sizeof (x) / sizeof *(x))
/* Round up to the next full cylinder size */
#define NUMSEC(size, sizemult, cylsize) \
((size) == ~0u ? ~0u : (sizemult) == 1 ? (size) : \
roundup((size) * (sizemult), (cylsize)))
/* What FS type? */
#define PI_ISBSDFS(p) ((p)->pi_fstype == FS_BSDLFS || \
(p)->pi_fstype == FS_BSDFFS)
/* standard cd0 device */
#define CD_NAMES "cd0a"
/* Types */
typedef struct distinfo {
const char *name;
uint set;
const char *desc;
const char *marker_file; /* set assumed installed if exists */
} distinfo;
#define MOUNTLEN 20
typedef struct _partinfo {
struct partition pi_partition;
#define pi_size pi_partition.p_size
#define pi_offset pi_partition.p_offset
#define pi_fsize pi_partition.p_fsize
#define pi_fstype pi_partition.p_fstype
#define pi_frag pi_partition.p_frag
#define pi_cpg pi_partition.p_cpg
char pi_mount[MOUNTLEN];
uint pi_isize; /* bytes per inode (for # inodes) */
uint pi_flags;
#define PIF_NEWFS 0x0001 /* need to 'newfs' partition */
#define PIF_FFSv2 0x0002 /* newfs with FFSv2, not FFSv1 */
#define PIF_MOUNT 0x0004 /* need to mount partition */
#define PIF_ASYNC 0x0010 /* mount -o async */
#define PIF_NOATIME 0x0020 /* mount -o noatime */
#define PIF_NODEV 0x0040 /* mount -o nodev */
#define PIF_NODEVMTIME 0x0080 /* mount -o nodevmtime */
#define PIF_NOEXEC 0x0100 /* mount -o noexec */
#define PIF_NOSUID 0x0200 /* mount -o nosuid */
#define PIF__UNUSED 0x0400 /* unused */
#define PIF_LOG 0x0800 /* mount -o log */
#define PIF_MOUNT_OPTS 0x0ff0 /* all above mount flags */
#define PIF_RESET 0x1000 /* internal - restore previous values */
const char *mnt_opts;
const char *fsname;
char mounted[MOUNTLEN];
int lvmpv; /* should we use partition as LVM PV? */
} partinfo; /* Single partition from a disklabel */
struct ptn_info {
int menu_no;
struct ptn_size {
int ptn_id;
char mount[MOUNTLEN];
daddr_t dflt_size;
daddr_t size;
int limit;
int changed;
} ptn_sizes[MAXPARTITIONS + 1]; /* +1 for delete code */
menu_ent ptn_menus[MAXPARTITIONS + 1]; /* +1 for unit chg */
int free_parts;
daddr_t free_space;
struct ptn_size *pool_part;
char exit_msg[70];
};
/* variables */
int debug; /* set by -D option */
char rel[SSTRSIZE];
char machine[SSTRSIZE];
int yesno;
int ignorerror;
int ttysig_ignore;
pid_t ttysig_forward;
int layoutkind;
int sizemult;
const char *multname;
int partman_go; /* run extended partition manager */
/* logging variables */
FILE *logfp;
FILE *script;
/* Information for the NetBSD disklabel */
enum DLTR { PART_A, PART_B, PART_C, PART_D, PART_E, PART_F, PART_G, PART_H,
PART_I, PART_J, PART_K, PART_L, PART_M, PART_N, PART_O, PART_P};
#define partition_name(x) ('a' + (x))
daddr_t tmp_ramdisk_size;
#define MAX_DISKS 15
unsigned int root_limit; /* BIOS (etc) read limit */
enum SHRED_T { SHRED_NONE=0, SHRED_ZEROS, SHRED_RANDOM, SHRED_CRYPTO };
/* All information that is unique for each drive */
SLIST_HEAD(pm_head_t, pm_devs_t) pm_head;
typedef struct pm_devs_t {
int unsaved; /* Flag indicating to partman that device need saving */
int found; /* Flag to delete unplugged and unconfigured devices */
int blocked; /* Device is busy and cannot be changed */
void *refdev; /* If device is blocked thats is a pointers to a parent dev */
int isspecial; /* LVM LV or DK device that doesnot accept disklabel */
char diskdev[SSTRSIZE]; /* Actual name of the disk. */
char diskdev_descr[STRSIZE];
int bootable;
#define DISKNAME_SIZE 16
char bsddiskname[DISKNAME_SIZE];
partinfo oldlabel[MAXPARTITIONS]; /* What we found on the disk */
partinfo bsdlabel[MAXPARTITIONS]; /* What we want it to look like */
int gpt;
int no_mbr; /* set for raid (etc) */
int rootpart; /* partition we install into */
const char *disktype; /* ST506, SCSI, ... */
const char *doessf;
/* Actual values for current disk - set by find_disks() or md_get_info() */
int sectorsize, dlcyl, dlhead, dlsec, dlcylsize, current_cylsize;
daddr_t dlsize;
/* Area of disk we can allocate, start and size in disk sectors. */
daddr_t ptstart, ptsize;
/* If we have an MBR boot partition, start and size in sectors */
int bootstart, bootsize;
struct ptn_info pi;
SLIST_ENTRY(pm_devs_t) l;
} pm_devs_t;
pm_devs_t *pm; /* Pointer to currend device with which we work */
pm_devs_t *pm_new; /* Pointer for next allocating device in find_disks() */
#define MAX_WEDGES 16 /* num of dk* devices */
typedef struct pm_wedge_t {
int allocated;
int todel;
pm_devs_t *pm;
int ptn;
} pm_wedge_t;
pm_wedge_t wedges[MAX_WEDGES];
/* Generic structure for partman */
typedef struct {
int retvalue;
int dev_num;
int wedge_num;
void *dev_ptr;
int dev_ptr_delta;
char fullname[SSTRSIZE];
enum {PM_DISK_T=1, PM_PART_T, PM_WEDGE_T, PM_SPEC_T, PM_RAID_T, PM_CGD_T,
PM_VND_T, PM_LVM_T, PM_LVMLV_T} type;
} part_entry_t;
/* Relative file name for storing a distribution. */
char xfer_dir[STRSIZE];
int clean_xfer_dir;
#if !defined(SYSINST_FTP_HOST)
#define SYSINST_FTP_HOST "ftp.NetBSD.org"
#endif
#if !defined(SYSINST_FTP_DIR)
#define SYSINST_FTP_DIR "pub/NetBSD/NetBSD-" REL
#endif
#if !defined(SYSINST_PKG_HOST)
#define SYSINST_PKG_HOST SYSINST_FTP_HOST
#endif
#if !defined(SYSINST_PKG_DIR)
#define SYSINST_PKG_DIR "pub/pkgsrc/packages/NetBSD"
#endif
#if !defined(SYSINST_PKGSRC_HOST)
#define SYSINST_PKGSRC_HOST SYSINST_PKG_HOST
#endif
/* Abs. path we extract binary sets from */
char ext_dir_bin[STRSIZE];
/* Abs. path we extract source sets from */
char ext_dir_src[STRSIZE];
/* Abs. path we extract pkgsrc from */
char ext_dir_pkgsrc[STRSIZE];
/* Place we look for binary sets in all fs types */
char set_dir_bin[STRSIZE];
/* Place we look for source sets in all fs types */
char set_dir_src[STRSIZE];
/* Place we look for pkgs in all fs types */
char pkg_dir[STRSIZE];
/* Place we look for pkgsrc in all fs types */
char pkgsrc_dir[STRSIZE];
/* User shell */
const char *ushell;
struct ftpinfo {
char host[STRSIZE];
char dir[STRSIZE] ;
char user[SSTRSIZE];
char pass[STRSIZE];
char proxy[STRSIZE];
const char *xfer_type; /* "ftp" or "http" */
};
/* use the same struct for sets ftp and to build pkgpath */
struct ftpinfo ftp, pkg, pkgsrc;
int (*fetch_fn)(const char *);
char nfs_host[STRSIZE];
char nfs_dir[STRSIZE];
char cdrom_dev[SSTRSIZE]; /* Typically "cd0a" */
char fd_dev[SSTRSIZE]; /* Typically "/dev/fd0a" */
const char *fd_type; /* "msdos", "ffs" or maybe "ados" */
char localfs_dev[SSTRSIZE];
char localfs_fs[SSTRSIZE];
char localfs_dir[STRSIZE];
char targetroot_mnt[SSTRSIZE];
int mnt2_mounted;
char dist_postfix[SSTRSIZE];
/* needed prototypes */
void set_menu_numopts(int, int);
void remove_color_options(void);
void remove_raid_options(void);
void remove_lvm_options(void);
void remove_cgd_options(void);
void remove_gpt_options(void);
/* Machine dependent functions .... */
void md_init(void);
void md_prelim_menu(void);
void md_init_set_status(int); /* SFLAG_foo */
/* MD functions if user selects install - in order called */
int md_get_info(void);
int md_make_bsd_partitions(void);
int md_check_partitions(void);
int md_pre_disklabel(void);
int md_post_disklabel(void);
int md_pre_mount(void);
int md_post_newfs(void);
int md_post_extract(void);
void md_cleanup_install(void);
/* MD functions if user selects upgrade - in order called */
int md_pre_update(void);
int md_update(void);
/* Also calls md_post_extract() */
/* from main.c */
void toplevel(void);
/* from disks.c */
const char *get_default_cdrom(void);
int find_disks(const char *);
struct menudesc;
void fmt_fspart(struct menudesc *, int, void *);
void disp_cur_fspart(int, int);
int write_disklabel(void);
int make_filesystems(void);
int make_fstab(void);
int mount_disks(void);
int set_swap(const char *, partinfo *);
int check_swap(const char *, int);
char *bootxx_name(void);
void label_read(void);
int get_dkwedges(struct dkwedge_info **, const char *);
const char *get_gptfs_by_id(int);
/* from disks_lfs.c */
int fs_is_lfs(void *);
/* from label.c */
const char *get_last_mounted(int, int, partinfo *);
int savenewlabel(partinfo *, int);
int incorelabel(const char *, partinfo *);
int edit_and_check_label(partinfo *, int, int, int);
void set_bsize(partinfo *, int);
void set_fsize(partinfo *, int);
void set_ptype(partinfo *, int, int);
int edit_ptn(menudesc *, void *);
int checkoverlap(partinfo *, int, int, int);
/* from install.c */
void do_install(void);
/* from factor.c */
void factor(long, long *, int, int *);
/* from fdisk.c */
void get_disk_info(char *);
void set_disk_info(char *);
/* from geom.c */
int get_geom(const char *, struct disklabel *);
int get_real_geom(const char *, struct disklabel *);
/* from net.c */
extern int network_up;
extern char net_namesvr[STRSIZE];
int get_via_ftp(const char *);
int get_via_nfs(void);
int config_network(void);
void mnt_net_config(void);
void make_url(char *, struct ftpinfo *, const char *);
int get_pkgsrc(void);
/* From run.c */
int collect(int, char **, const char *, ...) __printflike(3, 4);
int run_program(int, const char *, ...) __printflike(2, 3);
void do_logging(void);
int do_system(const char *);
/* from upgrade.c */
void do_upgrade(void);
void do_reinstall_sets(void);
void restore_etc(void);
/* from util.c */
int dir_exists_p(const char *);
int file_exists_p(const char *);
int file_mode_match(const char *, unsigned int);
uint get_ramsize(void);
void ask_sizemult(int);
void run_makedev(void);
int boot_media_still_needed(void);
int get_via_floppy(void);
int get_via_cdrom(void);
int get_via_localfs(void);
int get_via_localdir(void);
void show_cur_distsets(void);
void make_ramdisk_dir(const char *);
void set_kernel_set(unsigned int);
unsigned int get_kernel_set(void);
unsigned int set_X11_selected(void);
int get_and_unpack_sets(int, msg, msg, msg);
int sanity_check(void);
int set_timezone(void);
void scripting_fprintf(FILE *, const char *, ...) __printflike(2, 3);
void scripting_vfprintf(FILE *, const char *, va_list) __printflike(2, 0);
void add_rc_conf(const char *, ...);
int del_rc_conf(const char *);
void add_sysctl_conf(const char *, ...) __printflike(1, 2);
void enable_rc_conf(void);
void set_sizemultname_cyl(void);
void set_sizemultname_meg(void);
int binary_available(const char *);
int check_lfs_progs(void);
void init_set_status(int);
void customise_sets(void);
void umount_mnt2(void);
int set_is_source(const char *);
const char *set_dir_for_set(const char *);
const char *ext_dir_for_set(const char *);
void replace(const char *, const char *, ...);
void get_tz_default(void);
int extract_file(distinfo *, int);
void do_coloring (unsigned int, unsigned int);
int set_menu_select(menudesc *, void *);
const char *safectime(time_t *);
/* from target.c */
#if defined(DEBUG) || defined(DEBUG_ROOT)
void backtowin(void);
#endif
const char *concat_paths(const char *, const char *);
const char *target_expand(const char *);
void make_target_dir(const char *);
void append_to_target_file(const char *, const char *);
void echo_to_target_file(const char *, const char *);
void sprintf_to_target_file(const char *, const char *, ...)
__printflike(2, 3);
void trunc_target_file(const char *);
const char *target_prefix(void);
int target_chdir(const char *);
void target_chdir_or_die(const char *);
int target_already_root(void);
FILE *target_fopen(const char *, const char *);
int target_collect_file(int, char **, const char *);
int is_active_rootpart(const char *, int);
int cp_to_target(const char *, const char *);
void dup_file_into_target(const char *);
void mv_within_target_or_die(const char *, const char *);
int cp_within_target(const char *, const char *, int);
int target_mount(const char *, const char *, int, const char *);
int target_mount_do(const char *, const char *, const char *);
int target_test(unsigned int, const char *);
int target_dir_exists_p(const char *);
int target_file_exists_p(const char *);
int target_symlink_exists_p(const char *);
void unwind_mounts(void);
int target_mounted(void);
/* from partman.c */
int partman(void);
int pm_partusage(pm_devs_t *, int, int);
int pm_getrefdev(pm_devs_t *);
void pm_setfstype(pm_devs_t *, int, int);
int pm_editpart(int);
void pm_rename(pm_devs_t *);
int pm_shred(pm_devs_t *, int, int);
void pm_umount(pm_devs_t *, int);
int pm_unconfigure(pm_devs_t *);
int pm_cgd_edit(void *, part_entry_t *);
int pm_gpt_convert(pm_devs_t *);
void pm_wedges_fill(pm_devs_t *);
void pm_make_bsd_partitions(pm_devs_t *);
/* from bsddisklabel.c */
int make_bsd_partitions(void);
int save_ptn(int, daddr_t, daddr_t, int, const char *);
void set_ptn_titles(menudesc *, int, void *);
void set_ptn_menu(struct ptn_info *);
int set_ptn_size(menudesc *, void *);
void get_ptn_sizes(daddr_t, daddr_t, int);
int check_partitions(void);
/* from aout2elf.c */
int move_aout_libs(void);
#ifdef WSKBD
void get_kb_encoding(void);
void save_kb_encoding(void);
#else
#define get_kb_encoding()
#define save_kb_encoding()
#endif
/* from configmenu.c */
void do_configmenu(void);
/* from checkrc.c */
int check_rcvar(const char *);
int check_rcdefault(const char *);
WINDOW *mainwin;
#endif /* _DEFS_H_ */