Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/usr.sbin/sysinst add a size_t len to get_iso9660_volname() s...
details: https://anonhg.NetBSD.org/src/rev/567459166929
branches: trunk
changeset: 464399:567459166929
user: mrg <mrg%NetBSD.org@localhost>
date: Fri Oct 04 21:36:02 2019 +0000
description:
add a size_t len to get_iso9660_volname() so it can properly do
bounds checking.
ok martin@
diffstat:
usr.sbin/sysinst/util.c | 15 +++++++++------
1 files changed, 9 insertions(+), 6 deletions(-)
diffs (50 lines):
diff -r 25d3637626b8 -r 567459166929 usr.sbin/sysinst/util.c
--- a/usr.sbin/sysinst/util.c Fri Oct 04 21:33:57 2019 +0000
+++ b/usr.sbin/sysinst/util.c Fri Oct 04 21:36:02 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: util.c,v 1.33 2019/10/02 11:16:04 maya Exp $ */
+/* $NetBSD: util.c,v 1.34 2019/10/04 21:36:02 mrg Exp $ */
/*
* Copyright 1997 Piermont Information Systems Inc.
@@ -171,7 +171,8 @@
*/
static int check_for(unsigned int mode, const char *pathname);
-static int get_iso9660_volname(int dev, int sess, char *volname);
+static int get_iso9660_volname(int dev, int sess, char *volname,
+ size_t volnamelen);
static int get_available_cds(void);
static int binary_available(const char *prog);
@@ -377,7 +378,7 @@
* Get the volume name of a ISO9660 file system
*/
static int
-get_iso9660_volname(int dev, int sess, char *volname)
+get_iso9660_volname(int dev, int sess, char *volname, size_t volnamelen)
{
int blkno, error, last;
char buf[ISO_BLKSIZE];
@@ -394,8 +395,9 @@
if (isonum_711((const unsigned char *)&vd->type)
== ISO_VD_PRIMARY) {
pd = (struct iso_primary_descriptor*)buf;
- strncpy(volname, pd->volume_id, sizeof pd->volume_id);
- last = sizeof pd->volume_id-1;
+ strncpy(volname, pd->volume_id, volnamelen - 1);
+ volname[volnamelen - 1] = '\0';
+ last = volnamelen - 1;
while (last >= 0
&& (volname[last] == ' ' || volname[last] == 0))
last--;
@@ -456,7 +458,8 @@
dev = open(dname, O_RDONLY, 0);
if (dev == -1)
continue;
- error = get_iso9660_volname(dev, sess, volname);
+ error = get_iso9660_volname(dev, sess, volname,
+ sizeof volname);
close(dev);
if (error)
continue;
Home |
Main Index |
Thread Index |
Old Index