Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/usr.sbin/sysinst Fix /tmp tmpfs handling and on machines wit...
details: https://anonhg.NetBSD.org/src/rev/3638be0750c6
branches: trunk
changeset: 848065:3638be0750c6
user: martin <martin%NetBSD.org@localhost>
date: Thu Jan 16 16:47:19 2020 +0000
description:
Fix /tmp tmpfs handling and on machines with enough RAM default to
creating a /tmp tmpfs with 25% of ram size limit. Suggested by ad@.
diffstat:
usr.sbin/sysinst/bsddisklabel.c | 96 ++++++++++++++++++++++++++++++++--------
usr.sbin/sysinst/defs.h | 8 ++-
usr.sbin/sysinst/disks.c | 46 ++++++++++++-------
usr.sbin/sysinst/main.c | 3 +-
4 files changed, 112 insertions(+), 41 deletions(-)
diffs (295 lines):
diff -r a6a06fe8ea8c -r 3638be0750c6 usr.sbin/sysinst/bsddisklabel.c
--- a/usr.sbin/sysinst/bsddisklabel.c Thu Jan 16 15:29:24 2020 +0000
+++ b/usr.sbin/sysinst/bsddisklabel.c Thu Jan 16 16:47:19 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: bsddisklabel.c,v 1.34 2020/01/09 13:22:30 martin Exp $ */
+/* $NetBSD: bsddisklabel.c,v 1.35 2020/01/16 16:47:19 martin Exp $ */
/*
* Copyright 1997 Piermont Information Systems Inc.
@@ -236,8 +236,16 @@
size / sizemult);
}
size = pset->infos[opt].size;
- snprintf(psize, sizeof psize, "%" PRIu64 "%s",
- size / sizemult, inc_free);
+ if (pset->infos[opt].fs_type == FS_TMPFS) {
+ if (pset->infos[opt].size < 0)
+ snprintf(psize, sizeof psize, "%" PRIu64 "%%", -size);
+ else
+ snprintf(psize, sizeof psize, "%" PRIu64 " %s", size,
+ msg_string(MSG_megname));
+ } else {
+ snprintf(psize, sizeof psize, "%" PRIu64 "%s",
+ size / sizemult, inc_free);
+ }
if (pset->infos[opt].type == PT_swap) {
snprintf(swap, sizeof swap, "<%s>",
@@ -521,6 +529,20 @@
return NO_PART;
}
+static daddr_t
+parse_ram_size(const char *str, bool *is_percent)
+{
+ daddr_t val;
+ char *cp;
+
+ val = strtoull(str, &cp, 10);
+ while (*cp && isspace((unsigned char)*cp))
+ cp++;
+
+ *is_percent = *cp == '%';
+ return val;
+}
+
int
set_ptn_size(menudesc *m, void *arg)
{
@@ -531,7 +553,7 @@
size_t i, root = ~0U;
daddr_t size, old_size, new_size_val, mult;
int rv;
- bool non_zero, extend;
+ bool non_zero, extend, is_ram_size, is_percent = false;
if (pset->cur_free_space == 0 && p->size == 0 &&
!(p->flags & PUIFLG_JUST_MOUNTPOINT))
@@ -561,22 +583,47 @@
}
}
+ is_ram_size = (p->flags & PUIFLG_JUST_MOUNTPOINT)
+ && p->fs_type == FS_TMPFS;
+
size = p->size;
+ if (is_ram_size && size < 0) {
+ is_percent = true;
+ size = -size;
+ }
old_size = size;
if (size == 0)
size = p->def_size;
- size /= sizemult;
- snprintf(dflt, sizeof dflt, "%" PRIu64 "%s",
- size, p->flags & PUIFLAG_EXTEND ? "+" : "");
+ if (!is_ram_size)
+ size /= sizemult;
+
+ if (is_ram_size) {
+ snprintf(dflt, sizeof dflt, "%" PRIu64 "%s",
+ size, is_percent ? "%" : "");
+ } else {
+ snprintf(dflt, sizeof dflt, "%" PRIu64 "%s",
+ size, p->flags & PUIFLAG_EXTEND ? "+" : "");
+ }
for (;;) {
msg_fmt_prompt_win(MSG_askfssize, -1, 18, 0, 0,
- dflt, answer, sizeof answer, "%s%s", p->mount, multname);
+ dflt, answer, sizeof answer, "%s%s", p->mount,
+ is_ram_size ? msg_string(MSG_megname) : multname);
- /* cp will be checked below */
+ if (is_ram_size) {
+ new_size_val = parse_ram_size(answer, &is_percent);
+ if (is_percent &&
+ (new_size_val < 0 || new_size_val > 100))
+ continue;
+ if (!is_percent && new_size_val < 0)
+ continue;
+ size = new_size_val;
+ extend = false;
+ break;
+ }
mult = sizemult;
- new_size_val = parse_disk_pos(answer, &mult, pm->dlcylsize,
- &extend);
+ new_size_val = parse_disk_pos(answer, &mult,
+ pm->dlcylsize, &extend);
if (strcmp(answer, dflt) == 0)
non_zero = p->def_size > 0;
@@ -613,7 +660,9 @@
}
daddr_t align = pset->parts->pscheme->get_part_alignment(pset->parts);
- size = NUMSEC(size, mult, align);
+ if (!is_ram_size) {
+ size = NUMSEC(size, mult, align);
+ }
if (p->flags & PUIFLAG_EXTEND)
p->flags &= ~PUIFLAG_EXTEND;
if (extend && (p->limit == 0 || p->limit > p->size)) {
@@ -626,7 +675,7 @@
adjust_free:
if ((p->flags & (PUIFLG_IS_OUTER|PUIFLG_JUST_MOUNTPOINT)) == 0)
pset->cur_free_space += p->size - size;
- p->size = size;
+ p->size = is_percent ? -size : size;
set_pset_exit_str(pset);
return 0;
@@ -879,6 +928,20 @@
memcpy(wanted->infos, default_parts_init, sizeof(default_parts_init));
+#ifdef HAVE_TMPFS
+ if (get_ramsize() > 96) {
+ for (i = 0; i < wanted->num; i++) {
+ if (wanted->infos[i].type != PT_root ||
+ wanted->infos[i].fs_type != FS_TMPFS)
+ continue;
+ /* default tmpfs to 1/4 RAM */
+ wanted->infos[i].size = -25;
+ wanted->infos[i].def_size = -25;
+ break;
+ }
+ }
+#endif
+
#ifdef MD_PART_DEFAULTS
MD_PART_DEFAULTS(pm, wanted->infos, wanted->num);
#endif
@@ -918,11 +981,6 @@
#endif
}
}
- if ((wanted->infos[i].flags & PUIFLG_JUST_MOUNTPOINT) &&
- wanted->infos[i].size == 0)
- /* default tmpfs to 1/4 RAM */
- wanted->infos[i].def_size =
- get_ramsize() * (MEG/512/4);
}
/*
@@ -1131,7 +1189,7 @@
infos[pno].fs_version = info.fs_sub_type;
}
/* Add the non-partition entires after that */
- j = pset->num;
+ j = pset->parts->num_part;
for (i = 0; i < pset->num; i++) {
if (j >= no)
break;
diff -r a6a06fe8ea8c -r 3638be0750c6 usr.sbin/sysinst/defs.h
--- a/usr.sbin/sysinst/defs.h Thu Jan 16 15:29:24 2020 +0000
+++ b/usr.sbin/sysinst/defs.h Thu Jan 16 16:47:19 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: defs.h,v 1.50 2020/01/09 13:22:30 martin Exp $ */
+/* $NetBSD: defs.h,v 1.51 2020/01/16 16:47:19 martin Exp $ */
/*
* Copyright 1997 Piermont Information Systems Inc.
@@ -241,7 +241,10 @@
* layout according to the partitioning scheme backend.
*/
struct part_usage_info {
- daddr_t size; /* thumb guestimate of size [sec] */
+ daddr_t size; /* thumb guestimate of size,
+ * [sec if positive, %-of-ram
+ * if TMPFS and negative]
+ */
daddr_t def_size; /* default size */
daddr_t limit; /* max size */
char mount[MOUNTLEN]; /* where will we mount this? */
@@ -363,7 +366,6 @@
FILE *logfp;
FILE *script;
-daddr_t tmp_ramdisk_size;
#define MAX_DISKS 15
daddr_t root_limit; /* BIOS (etc) read limit */
diff -r a6a06fe8ea8c -r 3638be0750c6 usr.sbin/sysinst/disks.c
--- a/usr.sbin/sysinst/disks.c Thu Jan 16 15:29:24 2020 +0000
+++ b/usr.sbin/sysinst/disks.c Thu Jan 16 16:47:19 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: disks.c,v 1.59 2020/01/09 13:22:30 martin Exp $ */
+/* $NetBSD: disks.c,v 1.60 2020/01/16 16:47:19 martin Exp $ */
/*
* Copyright 1997 Piermont Information Systems Inc.
@@ -1299,7 +1299,11 @@
if (ptn->size == 0)
continue;
- if (ptn->type != PT_swap &&
+ bool is_tmpfs = ptn->type == PT_root &&
+ ptn->fs_type == FS_TMPFS &&
+ (ptn->flags & PUIFLG_JUST_MOUNTPOINT);
+
+ if (!is_tmpfs && ptn->type != PT_swap &&
(ptn->instflags & PUIINST_MOUNT) == 0)
continue;
@@ -1350,6 +1354,29 @@
scripting_fprintf(f, "%s\t\tnone\tswap\tsw%s\t\t 0 0\n",
dev, dump_dev);
continue;
+#ifdef HAVE_TMPFS
+ case FS_TMPFS:
+ if (ptn->size < 0)
+ scripting_fprintf(f,
+ "tmpfs\t\t/tmp\ttmpfs\trw,-m=1777,"
+ "-s=ram%%%" PRIu64 "\n", -ptn->size);
+ else
+ scripting_fprintf(f,
+ "tmpfs\t\t/tmp\ttmpfs\trw,-m=1777,"
+ "-s=%" PRIu64 "M\n", ptn->size);
+ continue;
+#else
+ case FS_MFS:
+ if (swap_dev[0] != 0)
+ scripting_fprintf(f,
+ "%s\t\t/tmp\tmfs\trw,-s=%"
+ PRIu64 "\n", swap_dev, ptn->size);
+ else
+ scripting_fprintf(f,
+ "swap\t\t/tmp\tmfs\trw,-s=%"
+ PRIu64 "\n", ptn->size);
+ continue;
+#endif
case FS_SYSVBFS:
fstype = "sysvbfs";
make_target_dir("/stand");
@@ -1379,21 +1406,6 @@
}
done_with_disks:
- if (tmp_ramdisk_size > 0) {
-#ifdef HAVE_TMPFS
- scripting_fprintf(f, "tmpfs\t\t/tmp\ttmpfs\trw,-m=1777,-s=%"
- PRIu64 "\n",
- tmp_ramdisk_size * 512);
-#else
- if (swap_dev[0] != 0)
- scripting_fprintf(f, "%s\t\t/tmp\tmfs\trw,-s=%"
- PRIu64 "\n", swap_dev, tmp_ramdisk_size);
- else
- scripting_fprintf(f, "swap\t\t/tmp\tmfs\trw,-s=%"
- PRIu64 "\n", tmp_ramdisk_size);
-#endif
- }
-
if (cdrom_dev[0] == 0)
get_default_cdrom(cdrom_dev, sizeof(cdrom_dev));
diff -r a6a06fe8ea8c -r 3638be0750c6 usr.sbin/sysinst/main.c
--- a/usr.sbin/sysinst/main.c Thu Jan 16 15:29:24 2020 +0000
+++ b/usr.sbin/sysinst/main.c Thu Jan 16 16:47:19 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: main.c,v 1.19 2019/12/11 15:08:45 martin Exp $ */
+/* $NetBSD: main.c,v 1.20 2020/01/16 16:47:19 martin Exp $ */
/*
* Copyright 1997 Piermont Information Systems Inc.
@@ -134,7 +134,6 @@
const struct f_arg *arg;
sizemult = 1;
- tmp_ramdisk_size = 0;
clean_xfer_dir = 0;
mnt2_mounted = 0;
fd_type = "msdos";
Home |
Main Index |
Thread Index |
Old Index