* "git clone" executed as root on solaris 10 shreds UFS (it is possible to create hardlinks for directories as root under solaris) @ 2007-07-16 10:08 Thomas Glanzmann 2007-07-16 10:43 ` Thomas Glanzmann ` (3 more replies) 0 siblings, 4 replies; 25+ messages in thread From: Thomas Glanzmann @ 2007-07-16 10:08 UTC (permalink / raw) To: GIT; +Cc: Linus Torvalds, Junio C Hamano Hello, when I call "git clone ~adglth0/work/scripts whatever" as user everything works as expected. As soon as I call this command as root it shreds ufs: (s092942) [~] git version git version 1.5.3.GIT (s092942) [~] git clone ~adglth0/work/scripts nonroot Initialized empty Git repository in /export/home/adglth0/nonroot/.git/ remote: Generating pack... Done counting 220 objects. Deltifying 220 objects... 2% (5/220) doneIndexing 220 objects... 100% (220/220) done20) donedonedone Total 220 (delta 114), reused 181remote: (delta 88) 100% (220/220) done Resolving 114 deltas... 100% (114/114) done (s092942) [~] cd nonroot ./nonroot (s092942) [~/nonroot] git status # On branch master nothing to commit (working directory clean) (s092942) [~/nonroot] fg sudo ${SHELL} --rcfile ${HOME}/.bash_profile (wd: ~) (s092942) [~] git clone ~adglth0/work/scripts root DO *NOT* RUN GIT AS ROOT clone /export/home/adglth0/work/scripts root (s092942) [~] unalias git (s092942) [~] git clone ~adglth0/work/scripts root Initialized empty Git repository in /export/home/adglth0/root/.git/ remote: Generating pack... remote: Done counting 220 objects. Deltifying 220 objects... 3% (7/220) doneIndexing 220 objects... 100% (220/220) done20) done0) done Total 220 (delta 114), reused 181 (delta 88) 100% (220/220) done Resolving 114 deltas... 100% (114/114) done (s092942) [~] cd root (s092942) [~/root] git status # On branch master # Changed but not updated: # (use "git add/rm <file>..." to update what will be committed) # # deleted: eclogic/acct_per_host.pl # deleted: eclogic/check_3ware # deleted: eclogic/check_ipmi.pl # deleted: eclogic/check_load.pl # deleted: eclogic/create_nagios_config.pl # deleted: eclogic/mailrelay/config-2.6.20 # deleted: eclogic/mailrelay/interfaces # deleted: eclogic/on_all_hosts.pl # deleted: lifebook/kernel-config # deleted: s017241/config-2.6.20 # deleted: s017241/firewall # deleted: s017241/siemens.conf # deleted: siemens/aliasupdate-tg # deleted: siemens/check_raid.sh # deleted: siemens/create_nagios_config.pl # deleted: siemens/crontab_client # deleted: siemens/deploy # deleted: siemens/generate_password.pl.gpg # deleted: siemens/mail_verrechnung.pl # deleted: siemens/oracle_beispiel_client.pl # deleted: siemens/sar_deploy.pl # deleted: siemens/t3_check_via_telnet.pl # deleted: thinkpad/config-2.6.20 # deleted: thinkpad/fglrx.patch # deleted: thinkpad/network-please # deleted: thinkpad/xorg/build # deleted: webfarm/config-2.6.20 # no changes added to commit (use "git add" and/or "git commit -a") (s092942) [~/root] git checkout -f HEAD (s092942) [~/root] git status # On branch master # Changed but not updated: # (use "git add/rm <file>..." to update what will be committed) # # deleted: eclogic/acct_per_host.pl # deleted: eclogic/check_3ware # deleted: eclogic/check_ipmi.pl # deleted: eclogic/check_load.pl # deleted: eclogic/create_nagios_config.pl # deleted: eclogic/mailrelay/config-2.6.20 # deleted: eclogic/mailrelay/interfaces # deleted: eclogic/sms.pl # deleted: lifebook/network-please # deleted: s017241/config-2.6.20 # deleted: s017241/firewall # deleted: s017241/xorg.conf # deleted: siemens/aliasupdate-tg # deleted: siemens/check_raid.sh # deleted: siemens/create_nagios_config.pl # deleted: siemens/crontab_client # deleted: siemens/deploy # deleted: siemens/generate_password.pl.gpg # deleted: siemens/mail_verrechnung.pl # deleted: siemens/oracle_beispiel_client.pl # deleted: siemens/sar_deploy.pl # deleted: siemens/tryserver.sh # deleted: thinkpad/config-2.6.20 # deleted: thinkpad/fglrx.patch # deleted: thinkpad/network-please # deleted: thinkpad/xorg/cleanup # deleted: webfarm/unsplit.pl # no changes added to commit (use "git add" and/or "git commit -a") (s092942) [~/root] ls eclogic/ leo* lifebook/ s017241/ siemens/ thinkpad/ webfarm/ (s092942) [~/root] ls siemens/ t3_check_via_telnet.pl* (s092942) [~/root] cd .. (s092942) [~] rm -rf root/ rm: Unable to remove directory root/: File exists (s092942) [~] find root/ root/ (s092942) [~] ls -al root/ total 6 drwxr-xr-x 56 root root 512 Jul 16 11:48 ./ drwxr-xr-x 17 adglth0 root 1536 Jul 16 11:48 ../ (s092942) [~] df -h . Filesystem size used avail capacity Mounted on /dev/dsk/c0t0d0s7 75G 9.0G 65G 13% /export/home (s092942) [~] ls -ali root/ total 6 13657 drwxr-xr-x 56 root root 512 Jul 16 11:48 ./ 5829 drwxr-xr-x 17 adglth0 root 1536 Jul 16 11:48 ../ (s092942) [~] gfind /export/home -xdev -inum 13657 /export/home/adglth0/root (s092942) [~] A few notes and observations I did. Linux _does_ not allow userland to create hardlinks for directories which makes totally sense. Solaris does allow the _root_ user to allow hardlinks for directories. There is even a command that makes that possible: (faui04a) [/var/tmp] mkdir test (faui04a) [/var/tmp] /usr/xpg4/bin/link test bla (faui04a) [/var/tmp] ls -ali total 13 1639 drwxrwxrwt 4 root sys 9216 Jul 16 11:13 ./ 4 drwxr-xr-x 48 root sys 1024 Jan 1 2007 ../ 238939 drwx--x--x 3 snalwuer icipguru 512 Jul 5 19:08 1071895580/ 238945 drwxr-xr-x 3 root root 512 Jul 16 11:11 bla/ 238945 drwxr-xr-x 3 root root 512 Jul 16 11:11 test/ (faui04a) [/var/tmp] find . -inum 238945 Whatever. My first impression was that the filesystem of the solaris is broken. So I fscked it. And guess what it corrected the error. But after the reboot I tried it again and you see the result above. So my guess is that git calls the link system call in a way Solaris thinks it should itself shoot in the head. This also happens with _remote_ clones as root: (s092942) [~] git clone adglth0@157.163.208.106:/home/adglth0/work/scripts second_test_as_root Initialized empty Git repository in /export/home/adglth0/second_test_as_root/.git/ The authenticity of host '157.163.208.106 (157.163.208.106)' can't be established. RSA key fingerprint is 72:27:be:82:f7:71:e5:23:a6:b6:57:a9:11:dd:26:26. Are you sure you want to continue connecting (yes/no)? yes Warning: Permanently added '157.163.208.106' (RSA) to the list of known hosts. remote: Generating pack... remote: Done counting 220 objects. remote: Deltifying 220 objects... remote: 100% (220/220) done Indexing 220 objects... remote: Total 220 (delta 115), reused 37 (delta 9) 100% (220/220) done Resolving 115 deltas... 100% (115/115) done (s092942) [~] cd second_test_as_root/ ./second_test_as_root/ (s092942) [~/second_test_as_root] git status # On branch master # Changed but not updated: # (use "git add/rm <file>..." to update what will be committed) # # deleted: eclogic/acct_per_host.pl # deleted: eclogic/check_3ware # deleted: eclogic/check_ipmi.pl # deleted: eclogic/check_load.pl # deleted: eclogic/create_nagios_config.pl # deleted: eclogic/mailrelay/config-2.6.20 # deleted: eclogic/mailrelay/interfaces # deleted: eclogic/on_all_hosts.pl # deleted: lifebook/kernel-config # deleted: s017241/config-2.6.20 # deleted: s017241/firewall # deleted: s017241/siemens.conf # deleted: siemens/aliasupdate-tg # deleted: siemens/check_raid.sh # deleted: siemens/create_nagios_config.pl # deleted: siemens/crontab_client # deleted: siemens/deploy # deleted: siemens/generate_password.pl.gpg # deleted: siemens/mail_verrechnung.pl # deleted: siemens/oracle_beispiel_client.pl # deleted: siemens/sar_deploy.pl # deleted: siemens/t3_check_via_telnet.pl # deleted: thinkpad/config-2.6.20 # deleted: thinkpad/fglrx.patch # deleted: thinkpad/network-please # deleted: thinkpad/xorg/build # deleted: webfarm/config-2.6.20 # no changes added to commit (use "git add" and/or "git commit -a") (s092942) [~/second_test_as_root] uname -a SunOS s092942 5.10 Generic_118833-17 sun4u sparc SUNW,Sun-Blade-100 So has anyone a idea what is wrong. I have shareded a second machine in a complete different domain. With a complete different git version. Same thing. So it is not the hardware and not the specific git version and not the Solaris version: (faui04a) [/var/tmp] git clone ~sithglan/work/sc screen/ scripts/ scripts_ccbank_what_the_hell/ (faui04a) [/var/tmp] git clone ~sithglan/work/repositories/ private/ public/ (faui04a) [/var/tmp] git clone ~sithglan/work/repositories/public/ blastwave.git/ bs.git/ easix.git/ mutt.git/ nzb.git/ ra.git/ watchdog.git/ (faui04a) [/var/tmp] git clone ~sithglan/work/repositories/public/easix.git/ DO *NOT* RUN GIT AS ROOT clone /home/cip/adm/sithglan/work/repositories/public/easix.git/ (faui04a) [/var/tmp] unalias git (faui04a) [/var/tmp] git clone ~sithglan/work/repositories/public/easix.git/ Initialized empty Git repository in /var/tmp/easix/.git/ remote: Generating pack... remote: Done counting 317 objects. remote: Deltifying 317 objects... remote: emote: 317/317) done: ) done17) done Indexing 317 objects... remote: Total 317 (delta 182), reused 278 (delta 157) 100% (317/317) done Resolving 182 deltas... 100% (182/182) done (faui04a) [/var/tmp] cd easix/ ./easix/ (faui04a) [/var/tmp/easix] git status # On branch master # Changed but not updated: # (use "git add/rm <file>..." to update what will be committed) # # deleted: profiles/icpc # deleted: profiles/sithglan # deleted: sources/boot.msg # deleted: sources/busybox-config # deleted: sources/config # deleted: sources/easix.logo.16 # deleted: sources/easixdm # deleted: sources/f2 # deleted: sources/home-faumachine.tar.gz # deleted: sources/home-icpc.tar.gz # deleted: sources/home-simigern.tar.gz # deleted: sources/home-sithglan.tar.gz # deleted: sources/home-sitowert.tar.gz # deleted: sources/linuxrc # deleted: sources/rc.local # no changes added to commit (use "git add" and/or "git commit -a") (faui04a) [/var/tmp/easix] cd .. (faui04a) [/var/tmp] rm -rf easix rm: Unable to remove directory easix: File exists (faui04a) [/var/tmp] ls -ali easix/ total 10 238947 drwxr-xr-x 17 root root 512 Jul 16 12:01 ./ 1639 drwxrwxrwt 5 root sys 9216 Jul 16 12:01 ../ (faui04a) [/var/tmp] git version git version 1.5.2 (faui04a) [/var/tmp] uname -a SunOS faui04a 5.10 Generic_118833-24 sun4u sparc SUNW,Sun-Fire-280R [ I am off the net for 30 mintues ... eating ] Thomas ^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: "git clone" executed as root on solaris 10 shreds UFS (it is possible to create hardlinks for directories as root under solaris) 2007-07-16 10:08 "git clone" executed as root on solaris 10 shreds UFS (it is possible to create hardlinks for directories as root under solaris) Thomas Glanzmann @ 2007-07-16 10:43 ` Thomas Glanzmann 2007-07-16 10:48 ` David Kastrup 2007-07-16 10:51 ` David Kastrup 2007-07-16 12:46 ` Thomas Glanzmann ` (2 subsequent siblings) 3 siblings, 2 replies; 25+ messages in thread From: Thomas Glanzmann @ 2007-07-16 10:43 UTC (permalink / raw) To: GIT; +Cc: Linus Torvalds, Junio C Hamano Hello, I narrowed it down. It is in "git checkout" if I copy the ".git" dir via "cp -a" and type in "git checkout" it breaks. And it _only_ breaks for subdirectories: (faui04a) [/var/tmp/shit] git checkout D profiles/icpc D profiles/sithglan D sources/boot.msg D sources/busybox-config D sources/config D sources/easix.logo.16 D sources/easixdm D sources/f2 D sources/home-faumachine.tar.gz D sources/home-icpc.tar.gz D sources/home-simigern.tar.gz D sources/home-sithglan.tar.gz D sources/home-sitowert.tar.gz D sources/linuxrc D sources/rc.local and I also see that _one_ file in each subdirectory is checked out but the others are not. Thomas ^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: "git clone" executed as root on solaris 10 shreds UFS (it is possible to create hardlinks for directories as root under solaris) 2007-07-16 10:43 ` Thomas Glanzmann @ 2007-07-16 10:48 ` David Kastrup 2007-07-16 12:35 ` Thomas Glanzmann 2007-07-16 10:51 ` David Kastrup 1 sibling, 1 reply; 25+ messages in thread From: David Kastrup @ 2007-07-16 10:48 UTC (permalink / raw) To: git Thomas Glanzmann <thomas@glanzmann.de> writes: > Hello, > I narrowed it down. It is in "git checkout" if I copy the ".git" dir via > "cp -a" and type in "git checkout" it breaks. And it _only_ breaks for > subdirectories: > > (faui04a) [/var/tmp/shit] git checkout > D profiles/icpc > D profiles/sithglan > D sources/boot.msg > D sources/busybox-config > D sources/config > D sources/easix.logo.16 > D sources/easixdm > D sources/f2 > D sources/home-faumachine.tar.gz > D sources/home-icpc.tar.gz > D sources/home-simigern.tar.gz > D sources/home-sithglan.tar.gz > D sources/home-sitowert.tar.gz > D sources/linuxrc > D sources/rc.local > > and I also see that _one_ file in each subdirectory is checked out but the > others are not. Ok, stupidly trying one of our most frequently encountered problems: Does it help to say export CDPATH="" in your root shell? -- David Kastrup ^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: "git clone" executed as root on solaris 10 shreds UFS (it is possible to create hardlinks for directories as root under solaris) 2007-07-16 10:48 ` David Kastrup @ 2007-07-16 12:35 ` Thomas Glanzmann 0 siblings, 0 replies; 25+ messages in thread From: Thomas Glanzmann @ 2007-07-16 12:35 UTC (permalink / raw) To: David Kastrup; +Cc: git, Linus Torvalds, Junio C Hamano Hello David, > Does it help to say export CDPATH="" in your root shell? no. The problem is triggered by "git-checkout-index -a -f" so my CDPATH has absolutly _nothing_ todo with it: (faui04a) [/var/tmp] mkdir -p test-4/.git (faui04a) [/var/tmp] cd test-4 (faui04a) [/var/tmp/test-4] gcp -a ~/work/repositories/public/easix.git/* .git/ (faui04a) [/var/tmp/test-4] git-read-tree HEAD (faui04a) [/var/tmp/test-4] git-checkout-index -a -f (faui04a) [/var/tmp/test-4] git status fatal: /usr/bin/git-status cannot be used without a working tree. (faui04a) [/var/tmp/test-4] rm .git/config (faui04a) [/var/tmp/test-4] git status # On branch master # Changed but not updated: # (use "git add/rm <file>..." to update what will be committed) # # deleted: profiles/icpc # deleted: profiles/sithglan # deleted: sources/boot.msg # deleted: sources/busybox-config # deleted: sources/config # deleted: sources/easix.logo.16 # deleted: sources/easixdm # deleted: sources/f2 # deleted: sources/home-faumachine.tar.gz # deleted: sources/home-icpc.tar.gz # deleted: sources/home-simigern.tar.gz # deleted: sources/home-sithglan.tar.gz # deleted: sources/home-sitowert.tar.gz # deleted: sources/linuxrc # deleted: sources/rc.local # no changes added to commit (use "git add" and/or "git commit -a") (faui04a) [/var/tmp/test-4] cd .. (faui04a) [/var/tmp] rm -rf test-4 rm: Unable to remove directory test-4: File exists (faui04a) [/var/tmp] Thomas ^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: "git clone" executed as root on solaris 10 shreds UFS (it is possible to create hardlinks for directories as root under solaris) 2007-07-16 10:43 ` Thomas Glanzmann 2007-07-16 10:48 ` David Kastrup @ 2007-07-16 10:51 ` David Kastrup 2007-07-16 12:39 ` Thomas Glanzmann 1 sibling, 1 reply; 25+ messages in thread From: David Kastrup @ 2007-07-16 10:51 UTC (permalink / raw) To: git Thomas Glanzmann <thomas@glanzmann.de> writes: > Hello, > I narrowed it down. It is in "git checkout" if I copy the ".git" dir via > "cp -a" and type in "git checkout" it breaks. And it _only_ breaks for > subdirectories: Another guess: cp -a copies files preserving all permissions and ownerships (which works only as root). Nominally, the files now don't belong to you, and some scripts might take you by the word even if they _could_ just overwrite things if they actually tried. Try making chown -R root.root .git on your tree and see whether this makes git more comfortable. -- David Kastrup ^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: "git clone" executed as root on solaris 10 shreds UFS (it is possible to create hardlinks for directories as root under solaris) 2007-07-16 10:51 ` David Kastrup @ 2007-07-16 12:39 ` Thomas Glanzmann 2007-07-16 12:58 ` David Kastrup 0 siblings, 1 reply; 25+ messages in thread From: Thomas Glanzmann @ 2007-07-16 12:39 UTC (permalink / raw) To: David Kastrup; +Cc: git Hello David, as I mentioned and showed in my original e-mail: git checkout /path/to/repo triggers the problem also. So no, "cp -a" has nothing todo with it because root is able to read _all_ files no matter who the files are owned by and what the permissions of these files are[1]. This happens on a _local_ fileystem. And what worries me is that git does something that breaks the _hard link counter_ of a directory. Thomas [1] Notes Of course that doesn't apply to all filesystems. For example AFS and NFS. But as I said before it happens on a _UFS_ filesystem. ^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: "git clone" executed as root on solaris 10 shreds UFS (it is possible to create hardlinks for directories as root under solaris) 2007-07-16 12:39 ` Thomas Glanzmann @ 2007-07-16 12:58 ` David Kastrup 2007-07-16 13:15 ` Thomas Glanzmann 0 siblings, 1 reply; 25+ messages in thread From: David Kastrup @ 2007-07-16 12:58 UTC (permalink / raw) To: git Thomas Glanzmann <thomas@glanzmann.de> writes: > Hello David, > as I mentioned and showed in my original e-mail: > > git checkout /path/to/repo > > triggers the problem also. So no, "cp -a" has nothing todo with it > because root is able to read _all_ files no matter who the files are > owned by and what the permissions of these files are[1]. This happens on > a _local_ fileystem. And what worries me is that git does something that > breaks the _hard link counter_ of a directory. Hm? The hard link counter is "broken" by creating or not creating subdirectories, since their ".." is a hard link. -- David Kastrup ^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: "git clone" executed as root on solaris 10 shreds UFS (it is possible to create hardlinks for directories as root under solaris) 2007-07-16 12:58 ` David Kastrup @ 2007-07-16 13:15 ` Thomas Glanzmann 2007-07-16 16:40 ` Thomas Glanzmann 0 siblings, 1 reply; 25+ messages in thread From: Thomas Glanzmann @ 2007-07-16 13:15 UTC (permalink / raw) To: David Kastrup; +Cc: GIT Hello David, > Hm? The hard link counter is "broken" by creating or not creating > subdirectories, since their ".." is a hard link. exactly. The question is: Is it a Solaris bug or is it something that is supposed a user is able to do (it doesn't make sense for me)? I posted this problem to comp.unix.solaris and also contacted the UFS Maintainer of Solaris (it is not the first UFS bug I original found). If I don't receive feedback, I am going to open a call with Sun. Whatever is going on (hopefully it isn't PEBKAC - but I don't think so) and this time it isn't broken hardware either (like the last time I reported a serious git bug) because it happens on two machines. Thomas ^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: "git clone" executed as root on solaris 10 shreds UFS (it is possible to create hardlinks for directories as root under solaris) 2007-07-16 13:15 ` Thomas Glanzmann @ 2007-07-16 16:40 ` Thomas Glanzmann 0 siblings, 0 replies; 25+ messages in thread From: Thomas Glanzmann @ 2007-07-16 16:40 UTC (permalink / raw) To: GIT Hello, > exactly. The question is: Is it a Solaris bug or is it something that is > supposed a user is able to do (it doesn't make sense for me)? I posted > this problem to comp.unix.solaris and also contacted the UFS Maintainer > of Solaris (it is not the first UFS bug I original found). If I don't > receive feedback, I am going to open a call with Sun. Whatever is going > on (hopefully it isn't PEBKAC - but I don't think so) and this time it > isn't broken hardware either (like the last time I reported a serious > git bug) because it happens on two machines. below I quote the answer of the UFS maintainer: Thomas, some notes on the unlink(directory) part: In the case of calling unlink(2) on a directory as a privilidged user, things like ".." (and the link count in the parent) would not be cleaned up. The man page for unlink(1M) and unlink(2) is very clear about using rmdir(1/2) to remove a directory. It's also very clear that this does exactly what it's supposed to do: Remove a link to a file/directory. Cleaning up the ".." entry (which would clean up the link to the parent) could be considered "extra". First the standards issues: The link(BA_OS) and unlink(BA_OS) descriptions in SVID3 both specify that a process with appropriate privileges is allowed to operate on a directory. We have claimed to conform to SVID3 since Solaris 2.0 and have not announced that we ever plan to EOL SVID3 conformance. UFS does support link(2)/unlink(2) with appropriate privilidges of directories while ZFS does not. The change that would provide ``Cleaning up the ".." entry ...'' would violate both SVID3 and POSIX and SUS requirements. (The unlink(path) system call is supposed to remove the directory entry named by path; not the directory entry named by path and an arbitrary number of other directory entries.) Second some history: Back before there were mkdir() and rmdir() system calls, applications wanting to create a directory invoked the setuid root mkdir utility which performed a series of mknod() and link() operations to create the directory and create dot and dot-dot entries in the new directory. Similarly, applications wanting to remove a directory invoked the setuid root rmdir uility which performed a series of unlink() operations to destroy the directory if it was empty. Not quite so far back in ancient history, there is also the point that before symlinks were available it was common practice to make hard links to directories. Privileged applications can still do this today (as mandated by SVID) using the link() and unlink() system calls and the link and unlink commands. UFS and ZFS are actually both correct, the standards wording permits either way kind of: <snip> If path1 names a directory, link() shall fail unless the process has appropriate privileges and the implementation supports using link() on directories. The path argument shall not name a directory unless the process has appropriate privileges and the implementation supports using unlink() on directories. <snip end> This seems to implicitely allow an escape route; we can declare that no process has sufficient privileges to link(2)/unlink(2) directories or like ZFS did, have the underlaying implementation not supporting it at all. The proper way is for the application to use the rmdir(2) system call, it's there since ages! my bottom line: GIT should not call unlink on a directory. Thomas ^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: "git clone" executed as root on solaris 10 shreds UFS (it is possible to create hardlinks for directories as root under solaris) 2007-07-16 10:08 "git clone" executed as root on solaris 10 shreds UFS (it is possible to create hardlinks for directories as root under solaris) Thomas Glanzmann 2007-07-16 10:43 ` Thomas Glanzmann @ 2007-07-16 12:46 ` Thomas Glanzmann 2007-07-16 13:36 ` Thomas Glanzmann 2007-07-16 13:45 ` Thomas Glanzmann 3 siblings, 0 replies; 25+ messages in thread From: Thomas Glanzmann @ 2007-07-16 12:46 UTC (permalink / raw) To: GIT; +Cc: Linus Torvalds, Junio C Hamano Hello again, it is definitively "git-checkout-index -a -f": truss output is at http://wwwcip.informatik.uni-erlangen.de/~sithglan/git_checkout_index_a_f.truss.gz Thomas ^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: "git clone" executed as root on solaris 10 shreds UFS (it is possible to create hardlinks for directories as root under solaris) 2007-07-16 10:08 "git clone" executed as root on solaris 10 shreds UFS (it is possible to create hardlinks for directories as root under solaris) Thomas Glanzmann 2007-07-16 10:43 ` Thomas Glanzmann 2007-07-16 12:46 ` Thomas Glanzmann @ 2007-07-16 13:36 ` Thomas Glanzmann 2007-07-16 16:29 ` David Kastrup 2007-07-16 17:03 ` Linus Torvalds 2007-07-16 13:45 ` Thomas Glanzmann 3 siblings, 2 replies; 25+ messages in thread From: Thomas Glanzmann @ 2007-07-16 13:36 UTC (permalink / raw) To: GIT; +Cc: Linus Torvalds, Junio C Hamano Hello, might that be related to the problem: lstat64("profiles/icpc", 0xFFBFF350) Err#2 ENOENT => mkdir("profiles", 0777) = 0 stat64(".git/objects/66/6197b02f46c92f0273f16ac77d34d76b28f4f0", 0xFFBFF088) = 0 open64(".git/objects/66/6197b02f46c92f0273f16ac77d34d76b28f4f0", O_RDONLY) = 4 mmap64(0x00000000, 284, PROT_READ, MAP_PRIVATE, 4, 0) = 0xFF230000 close(4) = 0 munmap(0xFF230000, 284) = 0 open64("profiles/icpc", O_WRONLY|O_CREAT|O_EXCL, 0666) = 4 open64("profiles/.gitattributes", O_RDONLY) Err#2 ENOENT write(4, " # I C P C P r o f i".., 420) = 420 close(4) = 0 lstat64("profiles/sithglan", 0xFFBFF350) Err#2 ENOENT => mkdir("profiles", 0777) Err#17 EEXIST => unlink("profiles") = 0 => mkdir("profiles", 0777) = 0 I think it is. Damn it. What seems to hapen here is that git does: - create a subdirectory - puts a file in - deletes a subdirectory (by call unlink - that would normally fail, but with solaris as root it does not fail) => here comes the dangling hard link counter - created the directory again - puts the file in That is why I only see one file in each subdirectory (the one that got checkedout last). So the fix for git should be straight forward. But I still think that Solaris is obviously broken. Because if you ask me it should not be possible to unlink a directory that has files in it?! Thomas ^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: "git clone" executed as root on solaris 10 shreds UFS (it is possible to create hardlinks for directories as root under solaris) 2007-07-16 13:36 ` Thomas Glanzmann @ 2007-07-16 16:29 ` David Kastrup 2007-07-16 17:03 ` Linus Torvalds 1 sibling, 0 replies; 25+ messages in thread From: David Kastrup @ 2007-07-16 16:29 UTC (permalink / raw) To: git Thomas Glanzmann <thomas@glanzmann.de> writes: > Hello, > might that be related to the problem: > > > lstat64("profiles/icpc", 0xFFBFF350) Err#2 ENOENT > => mkdir("profiles", 0777) = 0 > stat64(".git/objects/66/6197b02f46c92f0273f16ac77d34d76b28f4f0", > 0xFFBFF088) = 0 > open64(".git/objects/66/6197b02f46c92f0273f16ac77d34d76b28f4f0", > O_RDONLY) = 4 > mmap64(0x00000000, 284, PROT_READ, MAP_PRIVATE, 4, 0) = 0xFF230000 > close(4) = 0 > munmap(0xFF230000, 284) = 0 > open64("profiles/icpc", O_WRONLY|O_CREAT|O_EXCL, 0666) = 4 > open64("profiles/.gitattributes", O_RDONLY) Err#2 ENOENT > write(4, " # I C P C P r o f i".., 420) = 420 > close(4) = 0 > lstat64("profiles/sithglan", 0xFFBFF350) Err#2 ENOENT > => mkdir("profiles", 0777) Err#17 EEXIST > => unlink("profiles") = 0 > => mkdir("profiles", 0777) = 0 > > I think it is. Damn it. What seems to hapen here is that git does: > > - create a subdirectory > - puts a file in > - deletes a subdirectory (by call unlink - that would normally fail, > but with solaris as root it does not fail) > > => here comes the dangling hard link counter > > - created the directory again > - puts the file in > > That is why I only see one file in each subdirectory (the one that got > checkedout last). So the fix for git should be straight forward. But I still > think that Solaris is obviously broken. Because if you ask me it should not be > possible to unlink a directory that has files in it?! <URL:http://www.opengroup.org/onlinepubs/000095399/functions/unlink.html> The path argument shall not name a directory unless the process has appropriate privileges and the implementation supports using unlink() on directories. So Solaris has the right to do this. APPLICATION USAGE Applications should use rmdir() to remove a directory. RATIONALE Unlinking a directory is restricted to the superuser in many historical implementations for reasons given in link() (see also rename()). In short: git should not call remove, ever. It may succeed, and is a badly low-level call. If something is known to be a directory, then it needs to be removed using rmdir, and if it is a nondirectory, with unlink. Hm, browsing through Posix indicates that unlink is probably the same as remove. Pity. I thought that just "remove" was the potential evildoer. -- David Kastrup ^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: "git clone" executed as root on solaris 10 shreds UFS (it is possible to create hardlinks for directories as root under solaris) 2007-07-16 13:36 ` Thomas Glanzmann 2007-07-16 16:29 ` David Kastrup @ 2007-07-16 17:03 ` Linus Torvalds 2007-07-16 17:07 ` Linus Torvalds 1 sibling, 1 reply; 25+ messages in thread From: Linus Torvalds @ 2007-07-16 17:03 UTC (permalink / raw) To: Thomas Glanzmann; +Cc: GIT, Junio C Hamano On Mon, 16 Jul 2007, Thomas Glanzmann wrote: > > I think it is. Damn it. What seems to hapen here is that git does: > > - create a subdirectory > - puts a file in > - deletes a subdirectory (by call unlink - that would normally fail, > but with solaris as root it does not fail) Solaris is apparently a buggy piece of crap. I'd suggest making a bug-report. ENOTEMPTY is not an optional error. Posix says "Shall fail". Linus ^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: "git clone" executed as root on solaris 10 shreds UFS (it is possible to create hardlinks for directories as root under solaris) 2007-07-16 17:03 ` Linus Torvalds @ 2007-07-16 17:07 ` Linus Torvalds 2007-07-16 17:17 ` Thomas Glanzmann 0 siblings, 1 reply; 25+ messages in thread From: Linus Torvalds @ 2007-07-16 17:07 UTC (permalink / raw) To: Thomas Glanzmann; +Cc: GIT, Junio C Hamano On Mon, 16 Jul 2007, Linus Torvalds wrote: > > Solaris is apparently a buggy piece of crap. > > I'd suggest making a bug-report. ENOTEMPTY is not an optional error. Posix > says "Shall fail". Oh, it was apparetly "unlink()" that corrupts filesystems. Which isn't against Posix, it's just stupid. The "unlink directories" is so old-fashioned that it's not even funny. The whole reason "rmdir()" was created was to *not* have that behaviour in the OS. So I'll have to correct my statement. Please remove the "buggy" from "buggy piece of crap". The rest stands. Linus ^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: "git clone" executed as root on solaris 10 shreds UFS (it is possible to create hardlinks for directories as root under solaris) 2007-07-16 17:07 ` Linus Torvalds @ 2007-07-16 17:17 ` Thomas Glanzmann 2007-07-16 18:09 ` Thomas Glanzmann 0 siblings, 1 reply; 25+ messages in thread From: Thomas Glanzmann @ 2007-07-16 17:17 UTC (permalink / raw) To: Linus Torvalds; +Cc: GIT Hello Linus, > I'd suggest making a bug-report. ENOTEMPTY is not an optional error. > Posix says "Shall fail". The "unlink directories" is so old-fashioned > that it's not even funny. The whole reason "rmdir()" was created was > to *not* have that behaviour in the OS. I asked the UFS maintainer to reconsider to fix this. Thomas ^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: "git clone" executed as root on solaris 10 shreds UFS (it is possible to create hardlinks for directories as root under solaris) 2007-07-16 17:17 ` Thomas Glanzmann @ 2007-07-16 18:09 ` Thomas Glanzmann 2007-07-18 8:50 ` Thomas Glanzmann 0 siblings, 1 reply; 25+ messages in thread From: Thomas Glanzmann @ 2007-07-16 18:09 UTC (permalink / raw) To: Linus Torvalds; +Cc: GIT Hello, > I asked the UFS maintainer to reconsider to fix this. the bug is filed. Thomas ^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: "git clone" executed as root on solaris 10 shreds UFS (it is possible to create hardlinks for directories as root under solaris) 2007-07-16 18:09 ` Thomas Glanzmann @ 2007-07-18 8:50 ` Thomas Glanzmann 2007-07-18 15:45 ` Linus Torvalds 0 siblings, 1 reply; 25+ messages in thread From: Thomas Glanzmann @ 2007-07-18 8:50 UTC (permalink / raw) To: Linus Torvalds; +Cc: GIT Hello, > > I asked the UFS maintainer to reconsider to fix this. > the bug is filed. http://bugs.opensolaris.org/view_bug.do?bug_id=6581318 Thomas ^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: "git clone" executed as root on solaris 10 shreds UFS (it is possible to create hardlinks for directories as root under solaris) 2007-07-18 8:50 ` Thomas Glanzmann @ 2007-07-18 15:45 ` Linus Torvalds 2007-07-18 18:15 ` Thomas Glanzmann 0 siblings, 1 reply; 25+ messages in thread From: Linus Torvalds @ 2007-07-18 15:45 UTC (permalink / raw) To: Thomas Glanzmann; +Cc: GIT On Wed, 18 Jul 2007, Thomas Glanzmann wrote: > > > the bug is filed. > > http://bugs.opensolaris.org/view_bug.do?bug_id=6581318 I don't think the recipient "got it", since it already has a comment about "just use rmdir". Can you please tell them that that isn't the point? Linus ^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: "git clone" executed as root on solaris 10 shreds UFS (it is possible to create hardlinks for directories as root under solaris) 2007-07-18 15:45 ` Linus Torvalds @ 2007-07-18 18:15 ` Thomas Glanzmann 0 siblings, 0 replies; 25+ messages in thread From: Thomas Glanzmann @ 2007-07-18 18:15 UTC (permalink / raw) To: Linus Torvalds; +Cc: GIT Hello, > I don't think the recipient "got it", since it already has a comment about > "just use rmdir". Can you please tell them that that isn't the point? I already did. They got the point. I have confidence that they fix it. But there is no ETA. And the fix will not be backported. Thomas ^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: "git clone" executed as root on solaris 10 shreds UFS (it is possible to create hardlinks for directories as root under solaris) 2007-07-16 10:08 "git clone" executed as root on solaris 10 shreds UFS (it is possible to create hardlinks for directories as root under solaris) Thomas Glanzmann ` (2 preceding siblings ...) 2007-07-16 13:36 ` Thomas Glanzmann @ 2007-07-16 13:45 ` Thomas Glanzmann 2007-07-16 14:35 ` "git clone" executed as root on solaris 10 shreds UFS (it ispossible " Johannes Sixt 3 siblings, 1 reply; 25+ messages in thread From: Thomas Glanzmann @ 2007-07-16 13:45 UTC (permalink / raw) To: GIT; +Cc: Linus Torvalds, Junio C Hamano Hello, entry.c line 17: static void create_directories(const char *path, const struct checkout *state) { ... if (mkdir(buf, 0777)) { => if (errno == EEXIST) { struct stat st; => if (len > state->base_dir_len && state->force && !unlink(buf) && !mkdir(buf, 0777)) continue; if (!stat(buf, &st) && S_ISDIR(st.st_mode)) continue; /* ok */ } die("cannot create directory at %s", buf); } ... I think here is the problem. I don't understand what the code should do actually. Or why the directory is deleted and re-created (maybe something todo with permissions)? Thomas ^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: "git clone" executed as root on solaris 10 shreds UFS (it ispossible to create hardlinks for directories as root under solaris) 2007-07-16 13:45 ` Thomas Glanzmann @ 2007-07-16 14:35 ` Johannes Sixt 2007-07-16 15:45 ` Brian Downing 2007-07-16 17:12 ` Thomas Glanzmann 0 siblings, 2 replies; 25+ messages in thread From: Johannes Sixt @ 2007-07-16 14:35 UTC (permalink / raw) To: git; +Cc: Linus Torvalds, Junio C Hamano Thomas Glanzmann wrote: > static void create_directories(const char *path, const struct checkout *state) > { > ... > if (mkdir(buf, 0777)) { > => if (errno == EEXIST) { > struct stat st; > => if (len > state->base_dir_len && state->force && !unlink(buf) && !mkdir(buf, 0777)) > continue; > if (!stat(buf, &st) && S_ISDIR(st.st_mode)) > continue; /* ok */ > } > die("cannot create directory at %s", buf); > } > ... > > I think here is the problem. I don't understand what the code should do > actually. Or why the directory is deleted and re-created (maybe something todo > with permissions)? It tries to remove a *file* that is in the way and create the directory in its place. But since your unlink() behaves incorrectly (it is supposed to *fail* for directories), the logic does not quite work as expected - it mistakes the directory for a file. Try swapping the two inner-most if-blocks. -- Hannes ^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: "git clone" executed as root on solaris 10 shreds UFS (it ispossible to create hardlinks for directories as root under solaris) 2007-07-16 14:35 ` "git clone" executed as root on solaris 10 shreds UFS (it ispossible " Johannes Sixt @ 2007-07-16 15:45 ` Brian Downing 2007-07-16 15:50 ` Brian Downing 2007-07-16 19:57 ` David Kastrup 2007-07-16 17:12 ` Thomas Glanzmann 1 sibling, 2 replies; 25+ messages in thread From: Brian Downing @ 2007-07-16 15:45 UTC (permalink / raw) To: Johannes Sixt; +Cc: git, Linus Torvalds, Junio C Hamano On Mon, Jul 16, 2007 at 04:35:10PM +0200, Johannes Sixt wrote: > It tries to remove a *file* that is in the way and create the directory > in its place. But since your unlink() behaves incorrectly (it is > supposed to *fail* for directories), the logic does not quite work as > expected - it mistakes the directory for a file. http://www.opengroup.org/onlinepubs/007908799/xsh/unlink.html | The path argument must not name a directory unless the process has | appropriate privileges and the implementation supports using unlink() on | directories. The above seems to imply that implementations are free to do something with directories passed to unlink, and that it is the responsibility if the user not to do that unless they know what is going to happen. -bcd ^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: "git clone" executed as root on solaris 10 shreds UFS (it ispossible to create hardlinks for directories as root under solaris) 2007-07-16 15:45 ` Brian Downing @ 2007-07-16 15:50 ` Brian Downing 2007-07-16 19:57 ` David Kastrup 1 sibling, 0 replies; 25+ messages in thread From: Brian Downing @ 2007-07-16 15:50 UTC (permalink / raw) To: Johannes Sixt; +Cc: git, Linus Torvalds, Junio C Hamano On Mon, Jul 16, 2007 at 10:45:59AM -0500, Brian Downing wrote: > http://www.opengroup.org/onlinepubs/007908799/xsh/unlink.html > > | The path argument must not name a directory unless the process has > | appropriate privileges and the implementation supports using unlink() on > | directories. > > The above seems to imply that implementations are free to do something > with directories passed to unlink, and that it is the responsibility > if the user not to do that unless they know what is going to happen. Also, the HISTORY section of the FreeBSD manpages states: | The unlink system call traditionally allows the super-user to unlink | directories which can damage the filesystem integrity. This | implementation no longer permits it. Great. -bcd ^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: "git clone" executed as root on solaris 10 shreds UFS (it ispossible to create hardlinks for directories as root under solaris) 2007-07-16 15:45 ` Brian Downing 2007-07-16 15:50 ` Brian Downing @ 2007-07-16 19:57 ` David Kastrup 1 sibling, 0 replies; 25+ messages in thread From: David Kastrup @ 2007-07-16 19:57 UTC (permalink / raw) To: git bdowning@lavos.net (Brian Downing) writes: > On Mon, Jul 16, 2007 at 04:35:10PM +0200, Johannes Sixt wrote: >> It tries to remove a *file* that is in the way and create the directory >> in its place. But since your unlink() behaves incorrectly (it is >> supposed to *fail* for directories), the logic does not quite work as >> expected - it mistakes the directory for a file. > > http://www.opengroup.org/onlinepubs/007908799/xsh/unlink.html > > | The path argument must not name a directory unless the process has > | appropriate privileges and the implementation supports using unlink() on > | directories. Isn't it funny? The problem with the git code is that the path argument must not name a directory _if_ the process has appropriate privileges and the implementation supports using unlink() on directories. Failure is not an option, it is a requirement. -- David Kastrup, Kriemhildstr. 15, 44793 Bochum ^ permalink raw reply [flat|nested] 25+ messages in thread
* Re: "git clone" executed as root on solaris 10 shreds UFS (it ispossible to create hardlinks for directories as root under solaris) 2007-07-16 14:35 ` "git clone" executed as root on solaris 10 shreds UFS (it ispossible " Johannes Sixt 2007-07-16 15:45 ` Brian Downing @ 2007-07-16 17:12 ` Thomas Glanzmann 1 sibling, 0 replies; 25+ messages in thread From: Thomas Glanzmann @ 2007-07-16 17:12 UTC (permalink / raw) To: Johannes Sixt; +Cc: git, Linus Torvalds, Junio C Hamano Hello Johannes, > Try swapping the two inner-most if-blocks. I did and it works as expected: (faui04a) [/var/tmp] git clone ~sithglan/work/repositories/public/easix.git test-8 Initialized empty Git repository in /var/tmp/test-8/.git/ remote: Generating pack... remote: Done counting 317 objects. remote: Deltifying 317 objects... remote: 100% (317/317remote: ) done Indexing 317 objects... remote: Total 317 (delta 182), reused 278 (delta 157) 100% (317/317) done Resolving 182 deltas... 100% (182/182) done (faui04a) [/var/tmp] cd test-8 ./test-8 (faui04a) [/var/tmp/test-8] git status # On branch master nothing to commit (working directory clean) (faui04a) [/var/tmp/test-8] cd .. (faui04a) [/var/tmp] rm -rf test-8 ... I have a filesystem to check. :-) Thomas ^ permalink raw reply [flat|nested] 25+ messages in thread
end of thread, other threads:[~2007-07-18 18:15 UTC | newest] Thread overview: 25+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2007-07-16 10:08 "git clone" executed as root on solaris 10 shreds UFS (it is possible to create hardlinks for directories as root under solaris) Thomas Glanzmann 2007-07-16 10:43 ` Thomas Glanzmann 2007-07-16 10:48 ` David Kastrup 2007-07-16 12:35 ` Thomas Glanzmann 2007-07-16 10:51 ` David Kastrup 2007-07-16 12:39 ` Thomas Glanzmann 2007-07-16 12:58 ` David Kastrup 2007-07-16 13:15 ` Thomas Glanzmann 2007-07-16 16:40 ` Thomas Glanzmann 2007-07-16 12:46 ` Thomas Glanzmann 2007-07-16 13:36 ` Thomas Glanzmann 2007-07-16 16:29 ` David Kastrup 2007-07-16 17:03 ` Linus Torvalds 2007-07-16 17:07 ` Linus Torvalds 2007-07-16 17:17 ` Thomas Glanzmann 2007-07-16 18:09 ` Thomas Glanzmann 2007-07-18 8:50 ` Thomas Glanzmann 2007-07-18 15:45 ` Linus Torvalds 2007-07-18 18:15 ` Thomas Glanzmann 2007-07-16 13:45 ` Thomas Glanzmann 2007-07-16 14:35 ` "git clone" executed as root on solaris 10 shreds UFS (it ispossible " Johannes Sixt 2007-07-16 15:45 ` Brian Downing 2007-07-16 15:50 ` Brian Downing 2007-07-16 19:57 ` David Kastrup 2007-07-16 17:12 ` Thomas Glanzmann
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).