summaryrefslogtreecommitdiff
path: root/usr/src
diff options
context:
space:
mode:
authorRichard Lowe <richlowe@richlowe.net>2011-06-22 17:23:24 -0700
committerRichard Lowe <richlowe@richlowe.net>2011-06-22 17:23:24 -0700
commit09bb53675d4f606eb5c65c3876e23280387f4fb1 (patch)
treec163bbe57a6d610e6c5c188e903051cc02fa85ff /usr/src
parentb97d6ca7333c353b6ca20c20c99fb1be8d32a8de (diff)
downloadillumos-gate-09bb53675d4f606eb5c65c3876e23280387f4fb1.tar.gz
2062 libbc uname() deals with nodename/nodeext distastefully
Reviewed by: Joshua M. Clulow <josh@sysmgr.org> Reviewed by: Alexander Eremin <alexander.eremin@nexenta.com> Reviewed by: Robert Mustacchi <rm@joyent.com> Approved by: Gordon Ross <gwr@nexenta.com>
Diffstat (limited to 'usr/src')
-rw-r--r--usr/src/lib/libbc/libc/sys/common/uname.c33
1 files changed, 20 insertions, 13 deletions
diff --git a/usr/src/lib/libbc/libc/sys/common/uname.c b/usr/src/lib/libbc/libc/sys/common/uname.c
index ef09e18f63..3d890a5ce9 100644
--- a/usr/src/lib/libbc/libc/sys/common/uname.c
+++ b/usr/src/lib/libbc/libc/sys/common/uname.c
@@ -24,23 +24,21 @@
* Use is subject to license terms.
*/
-#pragma ident "%Z%%M% %I% %E% SMI"
-
#include <errno.h>
#include <string.h>
#include <sys/utsname.h>
#include <sys/syscall.h>
-/*
+/*
* utsname structure has a different format in SVr4/SunOS 5.0.
* The data needs to be mapped before returning to the user.
*/
-/*
+/*
* The following values and structure are from the SVR4 utsname.h.
*/
#define NEW_SYS_NMLN 257
-#define SYS_NMLN 9
+#define SYS_NMLN 9
#define SYS_NDLN 65
struct n_utsname {
@@ -51,14 +49,14 @@ struct n_utsname {
char machine[NEW_SYS_NMLN];
};
-int uname( uts )
-register struct utsname *uts; /* where to put results */
+int
+uname(struct utsname *uts)
{
- return(bc_uname(uts));
+ return (bc_uname(uts));
}
-int bc_uname( uts )
-struct utsname *uts;
+int
+bc_uname(struct utsname *uts)
{
struct n_utsname n_uts;
int ret;
@@ -67,9 +65,18 @@ struct utsname *uts;
memcpy(uts->sysname, n_uts.sysname, SYS_NMLN);
if (strlen(n_uts.sysname) > SYS_NMLN)
uts->sysname[SYS_NMLN-1] = '\0';
- memcpy(uts->nodename, n_uts.nodename, SYS_NDLN);
+
+ /*
+ * The nodename was originally 9 bytes (including NUL), but a
+ * field was added, following it, extending it to SYS_NDLN.
+ * So we have to copy it in two passes
+ */
+ memcpy(uts->nodename, n_uts.nodename, SYS_NMLN);
+ memcpy(uts->nodeext, n_uts.nodename + SYS_NMLN,
+ SYS_NDLN - SYS_NMLN);
if (strlen(n_uts.nodename) > SYS_NDLN)
- uts->nodename[SYS_NDLN-1] = '\0';
+ uts->nodeext[sizeof (uts->nodeext) - 1] = '\0';
+
memcpy(uts->release, n_uts.release, SYS_NMLN);
if (strlen(n_uts.release) > SYS_NMLN)
uts->release[SYS_NMLN-1] = '\0';
@@ -81,5 +88,5 @@ struct utsname *uts;
uts->machine[SYS_NMLN-1] = '\0';
}
- return(ret);
+ return (ret);
}