aboutsummaryrefslogtreecommitdiff
path: root/hurd/set-host.c
diff options
context:
space:
mode:
authorRoland McGrath <roland@gnu.org>1999-05-23 19:18:19 +0000
committerRoland McGrath <roland@gnu.org>1999-05-23 19:18:19 +0000
commit043032f443161389640449efa58e6ec9279684ce (patch)
treeba84200145997911c32baa904c9125154d63789a /hurd/set-host.c
parent8aba992a60cbe815ddcd14ffb51f2aa1186a6ed0 (diff)
downloadglibc-043032f443161389640449efa58e6ec9279684ce.tar
glibc-043032f443161389640449efa58e6ec9279684ce.tar.gz
glibc-043032f443161389640449efa58e6ec9279684ce.tar.bz2
glibc-043032f443161389640449efa58e6ec9279684ce.zip
1999-05-23 Roland McGrath <roland@baalperazim.frob.com>
* hurd/set-host.c (_hurd_set_host_config): Use mode 0644, not 0600. Do proper error return.
Diffstat (limited to 'hurd/set-host.c')
-rw-r--r--hurd/set-host.c11
1 files changed, 6 insertions, 5 deletions
diff --git a/hurd/set-host.c b/hurd/set-host.c
index eee50fc08e..889f532885 100644
--- a/hurd/set-host.c
+++ b/hurd/set-host.c
@@ -1,5 +1,5 @@
/* Set a host configuration item kept as the whole contents of a file.
- Copyright (C) 1996, 1997 Free Software Foundation, Inc.
+ Copyright (C) 1996, 1997, 1999 Free Software Foundation, Inc.
This file is part of the GNU C Library.
The GNU C Library is free software; you can redistribute it and/or
@@ -27,23 +27,24 @@ _hurd_set_host_config (const char *item, const char *value, size_t valuelen)
error_t err;
mach_msg_type_number_t nwrote;
file_t new, dir;
+ char *name;
- dir = __file_name_split (item, (char **)&item);
+ dir = __file_name_split (item, &name);
if (dir == MACH_PORT_NULL)
return -1;
/* Create a new node. */
- err = __dir_mkfile (dir, O_CREAT|O_TRUNC, 0600, &new);
+ err = __dir_mkfile (dir, O_CREAT|O_TRUNC, 0644, &new);
if (! err)
{
/* Write the contents. */
err = __io_write (new, value, valuelen, 0, &nwrote);
if (! err)
/* Atomically link the new node onto the name. */
- err = __dir_link (dir, new, item, 0);
+ err = __dir_link (dir, new, name, 0);
__mach_port_deallocate (__mach_task_self (), new);
}
__mach_port_deallocate (__mach_task_self (), dir);
- return nwrote;
+ return err ? __hurd_fail (err) : nwrote;
}