From 6affce8d5d4d82da72f5ef7661d5f1bab8b2b439 Mon Sep 17 00:00:00 2001 From: Felix Fietkau Date: Wed, 23 Mar 2005 14:31:49 +0000 Subject: [PATCH] make busybox passwd work when /etc/passwd is a symlink to /rom SVN-Revision: 431 --- .../busybox/patches/140-unlink-passwd.patch | 32 +++++++++++++++++++ 1 file changed, 32 insertions(+) create mode 100644 openwrt/package/busybox/patches/140-unlink-passwd.patch diff --git a/openwrt/package/busybox/patches/140-unlink-passwd.patch b/openwrt/package/busybox/patches/140-unlink-passwd.patch new file mode 100644 index 0000000000..07b6767e6e --- /dev/null +++ b/openwrt/package/busybox/patches/140-unlink-passwd.patch @@ -0,0 +1,32 @@ +--- busybox-1.00.old/loginutils/passwd.c 2004-09-15 04:39:09.000000000 +0200 ++++ busybox-1.00/loginutils/passwd.c 2005-03-23 15:31:07.000000000 +0100 +@@ -54,11 +54,12 @@ + snprintf(filename, sizeof filename, "%s", bb_path_passwd_file); + } + +- if (((fp = fopen(filename, "r+")) == 0) || (fstat(fileno(fp), &sb))) { ++ if (((fp = fopen(filename, "r")) == 0) || (fstat(fileno(fp), &sb))) { + /* return 0; */ + return 1; + } + ++#if 0 + /* Lock the password file before updating */ + lock.l_type = F_WRLCK; + lock.l_whence = SEEK_SET; +@@ -69,6 +70,7 @@ + return 1; + } + lock.l_type = F_UNLCK; ++#endif + + snprintf(buf, sizeof buf, "%s-", filename); + if (create_backup(buf, fp)) { +@@ -119,6 +121,7 @@ + fclose(fp); + return 1; + } ++ unlink(filename); + if (rename(buf, filename) < 0) { + fcntl(fileno(fp), F_SETLK, &lock); + fclose(fp); -- 2.30.2