Date: Mon, 17 Dec 2007 22:29:54 GMT From: Marcel Moolenaar <marcel@FreeBSD.org> To: Perforce Change Reviews <perforce@freebsd.org> Subject: PERFORCE change 131127 for review Message-ID: <200712172229.lBHMTsvn027571@repoman.freebsd.org>
next in thread | raw e-mail | index | archive | help
http://perforce.freebsd.org/chv.cgi?CH=131127 Change 131127 by marcel@marcel_cluster on 2007/12/17 22:29:36 IFC @131126 Affected files ... .. //depot/projects/e500/bin/mv/mv.c#2 integrate .. //depot/projects/e500/contrib/gdtoa/gdtoaimp.h#2 integrate .. //depot/projects/e500/contrib/gdtoa/hexnan.c#2 integrate .. //depot/projects/e500/contrib/gdtoa/strtod.c#2 integrate .. //depot/projects/e500/contrib/gdtoa/strtof.c#2 integrate .. //depot/projects/e500/contrib/gdtoa/strtorQ.c#2 integrate .. //depot/projects/e500/contrib/gdtoa/strtorx.c#2 integrate .. //depot/projects/e500/lib/libc/amd64/Symbol.map#4 integrate .. //depot/projects/e500/lib/libc/amd64/gd_qnan.h#2 integrate .. //depot/projects/e500/lib/libc/arm/gd_qnan.h#2 integrate .. //depot/projects/e500/lib/libc/gdtoa/Symbol.map#3 integrate .. //depot/projects/e500/lib/libc/i386/Symbol.map#4 integrate .. //depot/projects/e500/lib/libc/i386/gd_qnan.h#2 integrate .. //depot/projects/e500/lib/libc/ia64/Symbol.map#4 integrate .. //depot/projects/e500/lib/libc/ia64/gd_qnan.h#2 integrate .. //depot/projects/e500/lib/libc/net/nsdispatch.c#4 integrate .. //depot/projects/e500/lib/libc/sparc64/Symbol.map#4 integrate .. //depot/projects/e500/lib/libc/sparc64/gd_qnan.h#2 integrate .. //depot/projects/e500/lib/libc/stdlib/malloc.c#4 integrate .. //depot/projects/e500/lib/libc/stdlib/strtod.3#2 integrate .. //depot/projects/e500/lib/libkse/sys/thr_error.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_accept.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_aio_suspend.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_atfork.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_attr_destroy.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_attr_get_np.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_attr_getdetachstate.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_attr_getguardsize.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_attr_getinheritsched.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_attr_getschedparam.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_attr_getschedpolicy.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_attr_getscope.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_attr_getstack.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_attr_getstackaddr.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_attr_getstacksize.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_attr_init.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_attr_setcreatesuspend_np.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_attr_setdetachstate.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_attr_setguardsize.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_attr_setinheritsched.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_attr_setschedparam.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_attr_setschedpolicy.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_attr_setscope.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_attr_setstack.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_attr_setstackaddr.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_attr_setstacksize.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_barrier.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_barrierattr.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_cancel.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_clean.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_close.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_concurrency.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_cond.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_condattr_destroy.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_condattr_init.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_connect.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_creat.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_create.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_detach.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_equal.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_execve.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_exit.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_fcntl.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_fork.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_fsync.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_getprio.c#2 integrate .. //depot/projects/e500/lib/libkse/thread/thr_getschedparam.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_info.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_init.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_join.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_kill.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_main_np.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_mattr_init.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_mattr_kind_np.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_msync.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_multi_np.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_mutex.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_mutex_prioceiling.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_mutex_protocol.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_mutexattr_destroy.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_nanosleep.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_once.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_open.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_pause.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_poll.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_private.h#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_pselect.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_pspinlock.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_raise.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_read.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_readv.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_resume_np.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_rwlock.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_rwlockattr.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_select.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_self.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_sem.c#2 integrate .. //depot/projects/e500/lib/libkse/thread/thr_setprio.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_setschedparam.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_sigaction.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_sigaltstack.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_sigmask.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_sigpending.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_sigprocmask.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_sigsuspend.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_sigwait.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_single_np.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_sleep.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_spec.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_spinlock.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_suspend_np.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_switch_np.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_symbols.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_system.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_tcdrain.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_vfork.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_wait.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_wait4.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_waitpid.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_write.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_writev.c#3 integrate .. //depot/projects/e500/lib/libkse/thread/thr_yield.c#3 integrate .. //depot/projects/e500/lib/libthr/thread/thr_mutex.c#5 integrate .. //depot/projects/e500/lib/libufs/Makefile#2 integrate .. //depot/projects/e500/lib/libufs/block.c#2 integrate .. //depot/projects/e500/lib/libufs/bread.3#2 integrate .. //depot/projects/e500/lib/libufs/libufs.h#2 integrate .. //depot/projects/e500/lib/msun/Makefile#5 integrate .. //depot/projects/e500/lib/msun/Symbol.map#4 integrate .. //depot/projects/e500/lib/msun/amd64/Makefile.inc#2 integrate .. //depot/projects/e500/lib/msun/amd64/s_logbl.S#1 branch .. //depot/projects/e500/lib/msun/i387/Makefile.inc#2 integrate .. //depot/projects/e500/lib/msun/i387/s_logbl.S#1 branch .. //depot/projects/e500/lib/msun/ld128/s_nanl.c#1 branch .. //depot/projects/e500/lib/msun/ld80/s_nanl.c#1 branch .. //depot/projects/e500/lib/msun/man/ilogb.3#2 integrate .. //depot/projects/e500/lib/msun/man/math.3#2 integrate .. //depot/projects/e500/lib/msun/man/nan.3#1 branch .. //depot/projects/e500/lib/msun/src/math.h#2 integrate .. //depot/projects/e500/lib/msun/src/s_logb.c#2 integrate .. //depot/projects/e500/lib/msun/src/s_logbl.c#1 branch .. //depot/projects/e500/lib/msun/src/s_nan.c#1 branch .. //depot/projects/e500/release/doc/en_US.ISO8859-1/hardware/article.sgml#6 integrate .. //depot/projects/e500/release/doc/share/misc/dev.archlist.txt#5 integrate .. //depot/projects/e500/sbin/atacontrol/atacontrol.c#3 integrate .. //depot/projects/e500/sbin/growfs/growfs.c#2 integrate .. //depot/projects/e500/sbin/ipfw/ipfw2.c#6 integrate .. //depot/projects/e500/sbin/newfs/mkfs.c#2 integrate .. //depot/projects/e500/sbin/newfs/newfs.8#3 integrate .. //depot/projects/e500/sbin/newfs/newfs.c#3 integrate .. //depot/projects/e500/sbin/newfs/newfs.h#3 integrate .. //depot/projects/e500/sys/arm/at91/at91.c#2 integrate .. //depot/projects/e500/sys/arm/at91/if_ate.c#4 integrate .. //depot/projects/e500/sys/boot/powerpc/Makefile#4 integrate .. //depot/projects/e500/sys/boot/powerpc/ofw/Makefile#3 integrate .. //depot/projects/e500/sys/boot/powerpc/ofw/conf.c#2 integrate .. //depot/projects/e500/sys/boot/powerpc/ofw/help.ofw#2 integrate .. //depot/projects/e500/sys/boot/powerpc/ofw/ldscript.powerpc#2 integrate .. //depot/projects/e500/sys/boot/powerpc/ofw/metadata.c#2 integrate .. //depot/projects/e500/sys/boot/powerpc/ofw/start.c#2 integrate .. //depot/projects/e500/sys/boot/powerpc/ofw/version#2 integrate .. //depot/projects/e500/sys/cam/cam_xpt.c#6 integrate .. //depot/projects/e500/sys/conf/NOTES#9 integrate .. //depot/projects/e500/sys/conf/files#9 integrate .. //depot/projects/e500/sys/dev/cxgb/common/cxgb_t3_cpl.h#4 integrate .. //depot/projects/e500/sys/dev/cxgb/cxgb_adapter.h#6 integrate .. //depot/projects/e500/sys/dev/cxgb/cxgb_config.h#4 integrate .. //depot/projects/e500/sys/dev/cxgb/cxgb_include.h#4 integrate .. //depot/projects/e500/sys/dev/cxgb/cxgb_l2t.c#4 integrate .. //depot/projects/e500/sys/dev/cxgb/cxgb_l2t.h#4 integrate .. //depot/projects/e500/sys/dev/cxgb/cxgb_main.c#7 integrate .. //depot/projects/e500/sys/dev/cxgb/cxgb_offload.c#4 integrate .. //depot/projects/e500/sys/dev/cxgb/cxgb_offload.h#5 integrate .. //depot/projects/e500/sys/dev/cxgb/cxgb_osdep.h#6 integrate .. //depot/projects/e500/sys/dev/cxgb/cxgb_sge.c#6 integrate .. //depot/projects/e500/sys/dev/cxgb/sys/cxgb_support.c#1 branch .. //depot/projects/e500/sys/dev/cxgb/sys/mbufq.h#2 integrate .. //depot/projects/e500/sys/dev/cxgb/sys/mvec.h#4 integrate .. //depot/projects/e500/sys/dev/cxgb/sys/uipc_mvec.c#3 integrate .. //depot/projects/e500/sys/dev/cxgb/t3cdev.h#2 integrate .. //depot/projects/e500/sys/dev/cxgb/ulp/tom/cxgb_cpl_io.c#1 branch .. //depot/projects/e500/sys/dev/cxgb/ulp/tom/cxgb_cpl_socket.c#1 branch .. //depot/projects/e500/sys/dev/cxgb/ulp/tom/cxgb_defs.h#1 branch .. //depot/projects/e500/sys/dev/cxgb/ulp/tom/cxgb_listen.c#1 branch .. //depot/projects/e500/sys/dev/cxgb/ulp/tom/cxgb_t3_ddp.h#1 branch .. //depot/projects/e500/sys/dev/cxgb/ulp/tom/cxgb_tcp.h#1 branch .. //depot/projects/e500/sys/dev/cxgb/ulp/tom/cxgb_tcp_subr.c#1 branch .. //depot/projects/e500/sys/dev/cxgb/ulp/tom/cxgb_tcp_usrreq.c#1 branch .. //depot/projects/e500/sys/dev/cxgb/ulp/tom/cxgb_toepcb.h#1 branch .. //depot/projects/e500/sys/dev/cxgb/ulp/tom/cxgb_tom.c#1 branch .. //depot/projects/e500/sys/dev/cxgb/ulp/tom/cxgb_tom.h#1 branch .. //depot/projects/e500/sys/dev/cxgb/ulp/tom/cxgb_tom_sysctl.c#1 branch .. //depot/projects/e500/sys/dev/usb/uplcom.c#4 integrate .. //depot/projects/e500/sys/geom/geom_dev.c#2 integrate .. //depot/projects/e500/sys/geom/geom_io.c#3 integrate .. //depot/projects/e500/sys/i386/i386/machdep.c#7 integrate .. //depot/projects/e500/sys/kern/kern_event.c#4 integrate .. //depot/projects/e500/sys/kern/kern_thread.c#9 integrate .. //depot/projects/e500/sys/kern/kern_umtx.c#4 integrate .. //depot/projects/e500/sys/kern/sys_generic.c#5 integrate .. //depot/projects/e500/sys/kern/sys_pipe.c#4 integrate .. //depot/projects/e500/sys/kern/uipc_sockbuf.c#5 integrate .. //depot/projects/e500/sys/modules/Makefile#7 integrate .. //depot/projects/e500/sys/modules/cxgb/Makefile#6 integrate .. //depot/projects/e500/sys/modules/cxgb/cxgb/Makefile#2 integrate .. //depot/projects/e500/sys/modules/cxgb/tom/Makefile#1 branch .. //depot/projects/e500/sys/net/if_lagg.c#6 integrate .. //depot/projects/e500/sys/net/route.c#6 integrate .. //depot/projects/e500/sys/net/route.h#3 integrate .. //depot/projects/e500/sys/netinet/if_ether.c#5 integrate .. //depot/projects/e500/sys/netinet/if_ether.h#2 integrate .. //depot/projects/e500/sys/netinet/tcp.h#4 integrate .. //depot/projects/e500/sys/netinet/tcp_offload.c#1 branch .. //depot/projects/e500/sys/netinet/tcp_offload.h#1 branch .. //depot/projects/e500/sys/netinet/tcp_ofld.c#2 delete .. //depot/projects/e500/sys/netinet/tcp_ofld.h#2 delete .. //depot/projects/e500/sys/netinet/tcp_syncache.c#8 integrate .. //depot/projects/e500/sys/netinet/toedev.h#3 integrate .. //depot/projects/e500/sys/netinet6/in6_pcb.c#5 integrate .. //depot/projects/e500/sys/netncp/ncp_rq.c#2 integrate .. //depot/projects/e500/sys/netncp/ncp_sock.c#3 integrate .. //depot/projects/e500/sys/netncp/ncp_sock.h#2 integrate .. //depot/projects/e500/sys/netsmb/smb_trantcp.c#4 integrate .. //depot/projects/e500/sys/security/mac/mac_posix_sem.c#4 integrate .. //depot/projects/e500/sys/sys/ata.h#4 integrate .. //depot/projects/e500/sys/sys/lock_profile.h#6 integrate .. //depot/projects/e500/sys/sys/proc.h#8 integrate .. //depot/projects/e500/sys/sys/selinfo.h#2 integrate .. //depot/projects/e500/sys/sys/socketvar.h#2 integrate .. //depot/projects/e500/sys/sys/systm.h#7 integrate .. //depot/projects/e500/sys/sys/tty.h#2 integrate .. //depot/projects/e500/tools/regression/bin/mv/Makefile#1 branch .. //depot/projects/e500/tools/regression/bin/mv/regress.sh#1 branch .. //depot/projects/e500/tools/regression/bin/mv/regress.t#1 branch .. //depot/projects/e500/tools/regression/lib/libc/gen/test-wordexp.c#2 integrate .. //depot/projects/e500/tools/regression/lib/msun/Makefile#3 integrate .. //depot/projects/e500/tools/regression/lib/msun/test-nan.c#1 branch .. //depot/projects/e500/tools/regression/lib/msun/test-nan.t#1 branch .. //depot/projects/e500/tools/regression/lib/msun/test-next.c#3 integrate .. //depot/projects/e500/tools/regression/usr.bin/sed/multitest.t#2 integrate .. //depot/projects/e500/tools/regression/usr.bin/sed/regress.sh#3 integrate .. //depot/projects/e500/usr.bin/calendar/calendars/ru_RU.KOI8-R/calendar.common#2 integrate .. //depot/projects/e500/usr.sbin/iostat/iostat.c#4 integrate Differences ... ==== //depot/projects/e500/bin/mv/mv.c#2 (text+ko) ==== @@ -42,7 +42,7 @@ #endif /* not lint */ #endif #include <sys/cdefs.h> -__FBSDID("$FreeBSD: src/bin/mv/mv.c,v 1.46 2005/09/05 04:36:08 csjp Exp $"); +__FBSDID("$FreeBSD: src/bin/mv/mv.c,v 1.49 2007/12/17 09:02:42 dds Exp $"); #include <sys/types.h> #include <sys/acl.h> @@ -355,8 +355,34 @@ int copy(char *from, char *to) { + struct stat sb; + enum clean {CLEAN_SOURCE, CLEAN_DEST, CLEAN_ODEST, CLEAN_MAX}; + char *cleanup[CLEAN_MAX]; int pid, status; + volatile int i, rval; + + rval = 0; + for (i = 0; i < CLEAN_MAX; i++) + cleanup[i] = NULL; + /* + * If "to" exists and is a directory, get it out of the way. + * When the copy succeeds, delete it. + */ + if (stat(to, &sb) == 0 && S_ISDIR(sb.st_mode)) { + if (asprintf(&cleanup[CLEAN_ODEST], "%s.XXXXXX", to) == -1) { + warnx("asprintf failed"); + return (1); + } + if (rename(to, cleanup[CLEAN_ODEST]) < 0) { + warn("rename of existing target from %s to %s failed", + to, cleanup[CLEAN_ODEST]); + free(cleanup[CLEAN_ODEST]); + return (1); + } + } + /* Copy source to destination. */ + cleanup[CLEAN_DEST] = to; if ((pid = fork()) == 0) { execl(_PATH_CP, "mv", vflg ? "-PRpv" : "-PRp", "--", from, to, (char *)NULL); @@ -365,36 +391,77 @@ } if (waitpid(pid, &status, 0) == -1) { warn("%s: waitpid", _PATH_CP); - return (1); + rval = 1; + goto done; } if (!WIFEXITED(status)) { warnx("%s: did not terminate normally", _PATH_CP); - return (1); + rval = 1; + goto done; } if (WEXITSTATUS(status)) { warnx("%s: terminated with %d (non-zero) status", _PATH_CP, WEXITSTATUS(status)); - return (1); + rval = 1; + goto done; } - if (!(pid = vfork())) { - execl(_PATH_RM, "mv", "-rf", "--", from, (char *)NULL); - warn("%s", _PATH_RM); - _exit(1); + /* + * The copy succeeded. From now on the destination is where users + * will find their files. + */ + cleanup[CLEAN_DEST] = NULL; + cleanup[CLEAN_SOURCE] = from; +done: + /* Clean what needs to be cleaned. */ + for (i = 0; i < CLEAN_MAX; i++) { + if (cleanup[i] == NULL) + continue; + if (!(pid = vfork())) { + execl(_PATH_RM, "mv", "-rf", "--", cleanup[i], + (char *)NULL); + _exit(EX_OSERR); + } + if (waitpid(pid, &status, 0) == -1) { + warn("%s %s: waitpid", _PATH_RM, cleanup[i]); + rval = 1; + continue; + } + if (!WIFEXITED(status)) { + warnx("%s %s: did not terminate normally", + _PATH_RM, cleanup[i]); + rval = 1; + continue; + } + switch (WEXITSTATUS(status)) { + case 0: + break; + case EX_OSERR: + warnx("Failed to exec %s %s", _PATH_RM, cleanup[i]); + rval = 1; + continue; + default: + warnx("%s %s: terminated with %d (non-zero) status", + _PATH_RM, cleanup[i], WEXITSTATUS(status)); + rval = 1; + continue; + } + /* + * If the copy failed, and we just deleted the copy's trash, + * try to salvage the original destination, + */ + if (i == CLEAN_DEST && cleanup[CLEAN_ODEST]) { + if (rename(cleanup[CLEAN_ODEST], to) < 0) { + warn("rename back renamed existing target from %s to %s failed", + cleanup[CLEAN_ODEST], to); + rval = 1; + } + free(cleanup[CLEAN_ODEST]); + cleanup[CLEAN_ODEST] = NULL; + } } - if (waitpid(pid, &status, 0) == -1) { - warn("%s: waitpid", _PATH_RM); - return (1); - } - if (!WIFEXITED(status)) { - warnx("%s: did not terminate normally", _PATH_RM); - return (1); - } - if (WEXITSTATUS(status)) { - warnx("%s: terminated with %d (non-zero) status", - _PATH_RM, WEXITSTATUS(status)); - return (1); - } - return (0); + if (cleanup[CLEAN_ODEST]) + free(cleanup[CLEAN_ODEST]); + return (rval); } void ==== //depot/projects/e500/contrib/gdtoa/gdtoaimp.h#2 (text+ko) ==== @@ -26,7 +26,7 @@ ****************************************************************/ -/* $FreeBSD: src/contrib/gdtoa/gdtoaimp.h,v 1.8 2007/01/03 04:59:33 das Exp $ */ +/* $FreeBSD: src/contrib/gdtoa/gdtoaimp.h,v 1.9 2007/12/17 00:19:49 das Exp $ */ /* This is a variation on dtoa.c that converts arbitary binary floating-point formats to and from decimal notation. It uses @@ -169,6 +169,9 @@ #ifndef GDTOAIMP_H_INCLUDED #define GDTOAIMP_H_INCLUDED + +#define Long int + #include "gdtoa.h" #include "gd_qnan.h" ==== //depot/projects/e500/contrib/gdtoa/hexnan.c#2 (text+ko) ==== @@ -29,6 +29,8 @@ /* Please send bug reports to David M. Gay (dmg at acm dot org, * with " at " changed at "@" and " dot " changed to "."). */ +/* $FreeBSD: src/contrib/gdtoa/hexnan.c,v 1.2 2007/12/16 21:13:54 das Exp $ */ + #include "gdtoaimp.h" static void @@ -71,8 +73,14 @@ x1 = xe = x; havedig = hd0 = i = 0; s = *sp; + + /* FreeBSD local: Accept (but ignore) the '0x' prefix. */ + if (s[1] == '0' && (s[2] == 'x' || s[2] == 'X')) + s += 2; + while(c = *(CONST unsigned char*)++s) { if (!(h = hexdig[c])) { +#if 0 if (c <= ' ') { if (hd0 < havedig) { if (x < x1 && i < 8) @@ -92,7 +100,8 @@ *sp = s + 1; break; } - return STRTOG_NaN; +#endif + break; } havedig++; if (++i > 8) { @@ -103,9 +112,7 @@ } *x = (*x << 4) | h & 0xf; } - if (!havedig) - return STRTOG_NaN; - if (x < x1 && i < 8) + if (havedig && x < x1 && i < 8) L_shift(x, x1, i); if (x > x0) { x1 = x0; @@ -119,6 +126,7 @@ if ( (i = nbits & (ULbits-1)) !=0) *xe &= ((ULong)0xffffffff) >> (ULbits - i); } + if (havedig) { for(x1 = xe;; --x1) { if (*x1 != 0) break; @@ -127,5 +135,22 @@ break; } } + } + + /* + * FreeBSD local: Accept all the sequences allowed by C99 and update + * the tail pointer correctly. Don't accept any invalid sequences. + */ + if (c == '\0') /* nan() calls this, too; tolerate a missing ')' */ + return STRTOG_NaNbits; + if (c != ')') { + while(c = *(CONST unsigned char*)++s) { + if (c == ')') + break; + if (!isalnum(c) && c != '_') + return STRTOG_NaNbits; + } + } + *sp = s + 1; return STRTOG_NaNbits; } ==== //depot/projects/e500/contrib/gdtoa/strtod.c#2 (text+ko) ==== @@ -29,6 +29,8 @@ /* Please send bug reports to David M. Gay (dmg at acm dot org, * with " at " changed at "@" and " dot " changed to "."). */ +/* $FreeBSD: src/contrib/gdtoa/strtod.c,v 1.2 2007/12/16 21:14:33 das Exp $ */ + #include "gdtoaimp.h" #ifndef NO_FENV_H #include <fenv.h> @@ -258,7 +260,7 @@ if (*s == '(' /*)*/ && hexnan(&s, &fpinan, bits) == STRTOG_NaNbits) { - word0(rv) = 0x7ff00000 | bits[1]; + word0(rv) = 0x7ff80000 | bits[1]; word1(rv) = bits[0]; } else { ==== //depot/projects/e500/contrib/gdtoa/strtof.c#2 (text+ko) ==== @@ -29,6 +29,8 @@ /* Please send bug reports to David M. Gay (dmg at acm dot org, * with " at " changed at "@" and " dot " changed to "."). */ +/* $FreeBSD: src/contrib/gdtoa/strtof.c,v 1.2 2007/12/16 21:14:33 das Exp $ */ + #include "gdtoaimp.h" float @@ -52,10 +54,14 @@ break; case STRTOG_Normal: - case STRTOG_NaNbits: u.L[0] = bits[0] & 0x7fffff | exp + 0x7f + 23 << 23; break; + case STRTOG_NaNbits: + /* FreeBSD local: always return a quiet NaN */ + u.L[0] = bits[0] | 0x7fc00000; + break; + case STRTOG_Denormal: u.L[0] = bits[0]; break; ==== //depot/projects/e500/contrib/gdtoa/strtorQ.c#2 (text+ko) ==== @@ -29,6 +29,8 @@ /* Please send bug reports to David M. Gay (dmg at acm dot org, * with " at " changed at "@" and " dot " changed to "."). */ +/* $FreeBSD: src/contrib/gdtoa/strtorQ.c,v 1.3 2007/12/16 23:31:55 das Exp $ */ + #include "gdtoaimp.h" #undef _0 @@ -63,11 +65,18 @@ break; case STRTOG_Normal: + L[_3] = bits[0]; + L[_2] = bits[1]; + L[_1] = bits[2]; + L[_0] = (bits[3] & ~0x10000) | ((exp + 0x3fff + 112) << 16); + break; + case STRTOG_NaNbits: L[_3] = bits[0]; L[_2] = bits[1]; L[_1] = bits[2]; - L[_0] = (bits[3] & ~0x10000) | ((exp + 0x3fff + 112) << 16); + L[_0] = (bits[3] & ~0x10000) + | (((exp + 0x3fff + 112) << 16) | (1 << 15)); break; case STRTOG_Denormal: ==== //depot/projects/e500/contrib/gdtoa/strtorx.c#2 (text+ko) ==== @@ -29,6 +29,8 @@ /* Please send bug reports to David M. Gay (dmg at acm dot org, * with " at " changed at "@" and " dot " changed to "."). */ +/* $FreeBSD: src/contrib/gdtoa/strtorx.c,v 1.3 2007/12/16 23:31:55 das Exp $ */ + #include "gdtoaimp.h" #undef _0 @@ -69,7 +71,6 @@ goto normal_bits; case STRTOG_Normal: - case STRTOG_NaNbits: L[_0] = exp + 0x3fff + 63; normal_bits: L[_4] = (UShort)bits[0]; @@ -78,6 +79,14 @@ L[_1] = (UShort)(bits[1] >> 16); break; + case STRTOG_NaNbits: + L[_0] = exp + 0x3fff + 63; + L[_4] = (UShort)bits[0]; + L[_3] = (UShort)(bits[0] >> 16); + L[_2] = (UShort)bits[1]; + L[_1] = (UShort)((bits[1] >> 16) | (3 << 14)); + break; + case STRTOG_Infinite: L[_0] = 0x7fff; L[_1] = L[_2] = L[_3] = L[_4] = 0; ==== //depot/projects/e500/lib/libc/amd64/Symbol.map#4 (text) ==== @@ -1,5 +1,5 @@ /* - * $FreeBSD: src/lib/libc/amd64/Symbol.map,v 1.4 2007/05/31 13:01:32 deischen Exp $ + * $FreeBSD: src/lib/libc/amd64/Symbol.map,v 1.5 2007/12/16 21:15:56 das Exp $ */ /* @@ -71,4 +71,7 @@ _end; __sys_vfork; _vfork; + + /* used in libm */ + __ULtox_D2A; }; ==== //depot/projects/e500/lib/libc/amd64/gd_qnan.h#2 (text+ko) ==== @@ -4,18 +4,18 @@ * This file can be generated by compiling and running contrib/gdtoa/qnan.c * on the target architecture after arith.h has been generated. * - * $FreeBSD: src/lib/libc/amd64/gd_qnan.h,v 1.1 2007/01/03 05:00:02 das Exp $ + * $FreeBSD: src/lib/libc/amd64/gd_qnan.h,v 1.2 2007/12/16 21:15:08 das Exp $ */ -#define f_QNAN 0xffc00000 +#define f_QNAN 0x7fc00000 #define d_QNAN0 0x0 -#define d_QNAN1 0xfff80000 +#define d_QNAN1 0x7ff80000 #define ld_QNAN0 0x0 #define ld_QNAN1 0xc0000000 -#define ld_QNAN2 0xffff +#define ld_QNAN2 0x7fff #define ld_QNAN3 0x0 #define ldus_QNAN0 0x0 #define ldus_QNAN1 0x0 #define ldus_QNAN2 0x0 #define ldus_QNAN3 0xc000 -#define ldus_QNAN4 0xffff +#define ldus_QNAN4 0x7fff ==== //depot/projects/e500/lib/libc/arm/gd_qnan.h#2 (text+ko) ==== @@ -6,18 +6,18 @@ * * XXX I don't have ARM hardware, so I just guessed. --das * - * $FreeBSD: src/lib/libc/arm/gd_qnan.h,v 1.1 2007/01/03 05:00:02 das Exp $ + * $FreeBSD: src/lib/libc/arm/gd_qnan.h,v 1.2 2007/12/16 21:15:08 das Exp $ */ -#define f_QNAN 0xffc00000 +#define f_QNAN 0x7fc00000 #define d_QNAN0 0x0 -#define d_QNAN1 0xfff80000 +#define d_QNAN1 0x7ff80000 #define ld_QNAN0 0x0 #define ld_QNAN1 0xc0000000 -#define ld_QNAN2 0xffff +#define ld_QNAN2 0x7fff #define ld_QNAN3 0x0 #define ldus_QNAN0 0x0 #define ldus_QNAN1 0x0 #define ldus_QNAN2 0x0 #define ldus_QNAN3 0xc000 -#define ldus_QNAN4 0xffff +#define ldus_QNAN4 0x7fff ==== //depot/projects/e500/lib/libc/gdtoa/Symbol.map#3 (text) ==== @@ -1,5 +1,5 @@ /* - * $FreeBSD: src/lib/libc/gdtoa/Symbol.map,v 1.5 2007/10/13 14:40:16 deischen Exp $ + * $FreeBSD: src/lib/libc/gdtoa/Symbol.map,v 1.6 2007/12/16 21:15:56 das Exp $ */ FBSD_1.0 { @@ -12,3 +12,8 @@ /* FreeBSD additions */ strtold; }; + +FBSDprivate_1.0 { + /* used in libm */ + __hexnan_D2A; +}; ==== //depot/projects/e500/lib/libc/i386/Symbol.map#4 (text) ==== @@ -1,5 +1,5 @@ /* - * $FreeBSD: src/lib/libc/i386/Symbol.map,v 1.5 2007/05/31 13:01:33 deischen Exp $ + * $FreeBSD: src/lib/libc/i386/Symbol.map,v 1.6 2007/12/16 21:15:56 das Exp $ */ /* @@ -68,4 +68,7 @@ _brk; .curbrk; .minbrk; + + /* used in libm */ + __ULtox_D2A; }; ==== //depot/projects/e500/lib/libc/i386/gd_qnan.h#2 (text+ko) ==== @@ -4,18 +4,18 @@ * This file can be generated by compiling and running contrib/gdtoa/qnan.c * on the target architecture after arith.h has been generated. * - * $FreeBSD: src/lib/libc/i386/gd_qnan.h,v 1.1 2007/01/03 05:00:03 das Exp $ + * $FreeBSD: src/lib/libc/i386/gd_qnan.h,v 1.2 2007/12/16 21:15:08 das Exp $ */ -#define f_QNAN 0xffc00000 +#define f_QNAN 0x7fc00000 #define d_QNAN0 0x0 -#define d_QNAN1 0xfff80000 +#define d_QNAN1 0x7ff80000 #define ld_QNAN0 0x0 #define ld_QNAN1 0xc0000000 -#define ld_QNAN2 0xffff +#define ld_QNAN2 0x7fff #define ld_QNAN3 0x0 #define ldus_QNAN0 0x0 #define ldus_QNAN1 0x0 #define ldus_QNAN2 0x0 #define ldus_QNAN3 0xc000 -#define ldus_QNAN4 0xffff +#define ldus_QNAN4 0x7fff ==== //depot/projects/e500/lib/libc/ia64/Symbol.map#4 (text) ==== @@ -1,5 +1,5 @@ /* - * $FreeBSD: src/lib/libc/ia64/Symbol.map,v 1.4 2007/10/18 11:28:38 yar Exp $ + * $FreeBSD: src/lib/libc/ia64/Symbol.map,v 1.5 2007/12/16 21:15:57 das Exp $ */ /* @@ -69,4 +69,7 @@ minbrk; .cerror; curbrk; + + /* used in libm */ + __ULtox_D2A; }; ==== //depot/projects/e500/lib/libc/ia64/gd_qnan.h#2 (text+ko) ==== @@ -4,18 +4,18 @@ * This file can be generated by compiling and running contrib/gdtoa/qnan.c * on the target architecture after arith.h has been generated. * - * $FreeBSD: src/lib/libc/ia64/gd_qnan.h,v 1.1 2007/01/03 05:00:03 das Exp $ + * $FreeBSD: src/lib/libc/ia64/gd_qnan.h,v 1.2 2007/12/16 21:15:09 das Exp $ */ -#define f_QNAN 0xffc00000 +#define f_QNAN 0x7fc00000 #define d_QNAN0 0x0 -#define d_QNAN1 0xfff80000 +#define d_QNAN1 0x7ff80000 #define ld_QNAN0 0x0 #define ld_QNAN1 0xc0000000 -#define ld_QNAN2 0xffff +#define ld_QNAN2 0x7fff #define ld_QNAN3 0x0 #define ldus_QNAN0 0x0 #define ldus_QNAN1 0x0 #define ldus_QNAN2 0x0 #define ldus_QNAN3 0xc000 -#define ldus_QNAN4 0xffff +#define ldus_QNAN4 0x7fff ==== //depot/projects/e500/lib/libc/net/nsdispatch.c#4 (text+ko) ==== @@ -68,7 +68,7 @@ * */ #include <sys/cdefs.h> -__FBSDID("$FreeBSD: src/lib/libc/net/nsdispatch.c,v 1.15 2007/12/12 10:08:03 bushman Exp $"); +__FBSDID("$FreeBSD: src/lib/libc/net/nsdispatch.c,v 1.16 2007/12/17 16:12:57 bushman Exp $"); #include "namespace.h" #include <sys/param.h> @@ -592,9 +592,7 @@ return (match->method); } } - if (is_dynamic()) - nss_log(LOG_DEBUG, "%s, %s, %s, not found", source, database, - method); + *mdata = NULL; return (NULL); } @@ -701,12 +699,18 @@ if (result & (srclist[i].flags)) break; - } else if (fb_method != NULL) { - fallback_dispatch = 1; - va_start(ap, defaults); - result = fb_method(retval, (void *)srclist[i].name, ap); - va_end(ap); - fallback_dispatch = 0; + } else { + if (fb_method != NULL) { + fallback_dispatch = 1; + va_start(ap, defaults); + result = fb_method(retval, + (void *)srclist[i].name, ap); + va_end(ap); + fallback_dispatch = 0; + } else + nss_log(LOG_DEBUG, "%s, %s, %s, not found, " + "and no fallback provided", + srclist[i].name, database, method_name); } } ==== //depot/projects/e500/lib/libc/sparc64/Symbol.map#4 (text) ==== @@ -1,5 +1,5 @@ /* - * $FreeBSD: src/lib/libc/sparc64/Symbol.map,v 1.5 2007/05/31 13:01:34 deischen Exp $ + * $FreeBSD: src/lib/libc/sparc64/Symbol.map,v 1.6 2007/12/16 21:15:57 das Exp $ */ /* @@ -96,4 +96,7 @@ /* used in src/lib/csu/sparc64/crt1.c */ __sparc_utrap_setup; + + /* used in libm */ + __ULtoQ_D2A; }; ==== //depot/projects/e500/lib/libc/sparc64/gd_qnan.h#2 (text+ko) ==== @@ -4,18 +4,18 @@ * This file can be generated by compiling and running contrib/gdtoa/qnan.c * on the target architecture after arith.h has been generated. * - * $FreeBSD: src/lib/libc/sparc64/gd_qnan.h,v 1.1 2007/01/03 05:00:03 das Exp $ + * $FreeBSD: src/lib/libc/sparc64/gd_qnan.h,v 1.2 2007/12/16 21:15:09 das Exp $ */ -#define f_QNAN 0x7fffffff -#define d_QNAN0 0x7fffffff -#define d_QNAN1 0xffffffff -#define ld_QNAN0 0x7fffffff -#define ld_QNAN1 0xffffffff -#define ld_QNAN2 0xffffffff -#define ld_QNAN3 0xffffffff +#define f_QNAN 0x7fc00000 +#define d_QNAN0 0x7ff80000 +#define d_QNAN1 0x00000000 +#define ld_QNAN0 0x7fff8000 +#define ld_QNAN1 0x00000000 +#define ld_QNAN2 0x00000000 +#define ld_QNAN3 0x00000000 #define ldus_QNAN0 0x7fff -#define ldus_QNAN1 0xffff -#define ldus_QNAN2 0xffff -#define ldus_QNAN3 0xffff -#define ldus_QNAN4 0xffff +#define ldus_QNAN1 0x8000 +#define ldus_QNAN2 0x0000 +#define ldus_QNAN3 0x0000 +#define ldus_QNAN4 0x0000 ==== //depot/projects/e500/lib/libc/stdlib/malloc.c#4 (text+ko) ==== @@ -104,8 +104,22 @@ # define MALLOC_DEBUG #endif +/* + * MALLOC_LAZY_FREE enables the use of a per-thread vector of slots that free() + * can atomically stuff object pointers into. This can reduce arena lock + * contention. + */ +#define MALLOC_LAZY_FREE + +/* + * MALLOC_BALANCE enables monitoring of arena lock contention and dynamically + * re-balances arena load if exponentially averaged contention exceeds a + * certain threshold. + */ +#define MALLOC_BALANCE + #include <sys/cdefs.h> -__FBSDID("$FreeBSD: src/lib/libc/stdlib/malloc.c,v 1.152 2007/11/28 00:17:34 jasone Exp $"); +__FBSDID("$FreeBSD: src/lib/libc/stdlib/malloc.c,v 1.153 2007/12/17 01:20:04 jasone Exp $"); #include "libc_private.h" #ifdef MALLOC_DEBUG @@ -216,6 +230,17 @@ # define NO_TLS #endif +#ifdef NO_TLS + /* MALLOC_BALANCE requires TLS. */ +# ifdef MALLOC_BALANCE +# undef MALLOC_BALANCE +# endif + /* MALLOC_LAZY_FREE requires TLS. */ +# ifdef MALLOC_LAZY_FREE +# undef MALLOC_LAZY_FREE +# endif +#endif + /* * Size and alignment of memory chunks that are allocated by the OS's virtual * memory system. @@ -261,8 +286,9 @@ #define RUN_MAX_SMALL_2POW 15 #define RUN_MAX_SMALL (1U << RUN_MAX_SMALL_2POW) +#ifdef MALLOC_LAZY_FREE /* Default size of each arena's lazy free cache. */ -#define LAZY_FREE_2POW_DEFAULT 8 +# define LAZY_FREE_2POW_DEFAULT 8 /* * Number of pseudo-random probes to conduct before considering the cache to be * overly full. It takes on average n probes to detect fullness of (n-1)/n. @@ -270,7 +296,8 @@ * deallocation is a trial), so the actual average threshold for clearing the * cache is somewhat lower. */ -#define LAZY_FREE_NPROBES 5 +# define LAZY_FREE_NPROBES 5 +#endif /* * Hyper-threaded CPUs may need a special instruction inside spin loops in @@ -295,6 +322,7 @@ */ #define BLOCK_COST_2POW 4 +#ifdef MALLOC_BALANCE /* * We use an exponential moving average to track recent lock contention, where * the size of the history window is N, and alpha=2/(N+1). @@ -303,13 +331,14 @@ * degradation in accuracy, thus making the moving average decay faster than it * would with precise calculation. */ -#define BALANCE_ALPHA_INV_2POW 9 +# define BALANCE_ALPHA_INV_2POW 9 /* * Threshold value for the exponential moving contention average at which to * re-assign a thread. */ -#define BALANCE_THRESHOLD_DEFAULT (1U << (SPIN_LIMIT_2POW-4)) +# define BALANCE_THRESHOLD_DEFAULT (1U << (SPIN_LIMIT_2POW-4)) +#endif /******************************************************************************/ @@ -373,7 +402,7 @@ uint64_t nmalloc_large; uint64_t ndalloc_large; -#ifndef NO_TLS +#ifdef MALLOC_BALANCE /* Number of times this arena reassigned a thread due to contention. */ uint64_t nbalance; #endif @@ -587,13 +616,15 @@ */ arena_chunk_t *spare; -#ifndef NO_TLS >>> TRUNCATED FOR MAIL (1000 lines) <<<
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200712172229.lBHMTsvn027571>