From owner-freebsd-bugs Sat Dec 28 08:01:06 1996 Return-Path: Received: (from root@localhost) by freefall.freebsd.org (8.8.4/8.8.4) id IAA15955 for bugs-outgoing; Sat, 28 Dec 1996 08:01:06 -0800 (PST) Received: from godzilla.zeta.org.au (godzilla.zeta.org.au [203.2.228.19]) by freefall.freebsd.org (8.8.4/8.8.4) with ESMTP id IAA15950 for ; Sat, 28 Dec 1996 08:01:02 -0800 (PST) Received: (from bde@localhost) by godzilla.zeta.org.au (8.8.3/8.6.9) id CAA22346; Sun, 29 Dec 1996 02:57:12 +1100 Date: Sun, 29 Dec 1996 02:57:12 +1100 From: Bruce Evans Message-Id: <199612281557.CAA22346@godzilla.zeta.org.au> To: bde@zeta.org.au, dg@root.com Subject: Re: another POSIX access timestamp pessimization Cc: bugs@freebsd.org Sender: owner-bugs@freebsd.org X-Loop: FreeBSD.org Precedence: bulk >>POSIX says that "Upon successful completion, the exec functions shall >>mark for update the st_atime field of the file". Not content with > > In my opinion, "tough". This is one part of POSIX that I'm not interested >in being compatible with since the cost is too great. It may not be much of >an issue at exec time, but the disk I/O caused by the update of the access >time that occurs later is extremely expensive. This problem affects many things other than the access times for exec'ed binaries, even for exec itself for shared libraries. E.g., execing /usr/bin/du accesses the following files: ld.so (crt0 begins by reading 0x20 bytes from this, so its access time gets set. After that it is only accessed via mmap(), which I think doesn't set the access time, but probably should (at fault time)) ld.so.hints (ld.so begins by reading 0x20 bytes from this) libc.so.3.0 (ld.so begins by reading 0x20 bytes from this) crt0 and ld.so read the a.out header for some reason before mmapping the whole file. Of course, the problem is not so large because there are only a few library files so caching works. I forgot to say that the access time already gets set when scripts are execed, since something has to read the script. Access times are set on exec in Linux-2.0.27. Bruce