From: Federico Sauter <fsauter-LVkJPw3T+odGBRGhe+f61g@public.gmane.org>
To: Pavel Shilovsky <piastryyy-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
Cc: Jeff Layton <jlayton-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>,
linux-cifs-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
Subject: Re: Inode link count on mounted Win98 shares
Date: Thu, 22 Mar 2012 10:28:18 +0100 [thread overview]
Message-ID: <4F6AF0B2.1070403@innominate.com> (raw)
In-Reply-To: <CAKywueR4v0MVpL-LoNsyjcDgzV3Tp9hkOvK3gLOP9o-SkJX_bQ-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
On 03/21/2012 07:24 PM, Pavel Shilovsky wrote:
> 21 марта 2012 г. 21:23 пользователь Jeff Layton<jlayton-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org> написал:
>> On Wed, 21 Mar 2012 12:18:17 +0100
>> Federico Sauter<fsauter-LVkJPw3T+odGBRGhe+f61g@public.gmane.org> wrote:
>>
>>> Greetings,
>>>
>>> I want to make some CIFS shared drives accesible through a firewall. For
>>> that sake, I have a CIFS shared drive on a Linux box (box0, kernel
>>> 2.6.27.57) which is accesible from outside the firewall. On the share on
>>> that box I mount all the shared drives from within the firewall so that
>>> they can be accessed from client-external.
>>>
>>> client-external
>>> 172.16.1.2
>>> |
>>> |
>>> 172.16.1.1/24
>>> box0 (router, firewall)
>>> 192.168.1.1/24
>>> |
>>> +------+-------+
>>> | |
>>> win98 winxp
>>> 192.168.1.2 192.168.1.3
>>>
>>> box0 exports a CIFS shared drive, say \\172.16.1.1\testshare, which
>>> refers to local directory, /mnt/share. On /mnt/share I mount two further
>>> shared drives, say win98 and winxp. Thus, the contents from win98 and
>>> winxp become indirectly visible to the external network
>>> (client-external) via 172.16.1.1.
>>>
>>> This works well if I mount \\172.16.1.1\testshare using a Linux-based
>>> client-external. Everything works as expected and I can browse the
>>> contents of both, winxp and win98. However, when I mount
>>> \\172.16.1.1\testshare on a Windows machine, I am unable to browse the
>>> contents of the win98 directory. While the winxp directory appears
>>> correctly as a folder in the Windows Explorer, the win98 directory
>>> appears as a zero byte file (even though it is mounted correctly on box0.)
>>>
>>> I tested the same setup using my local workstation (with Debian squeeze,
>>> kernel 2.6.32-5) and came to the same observations. The only difference
>>> I could find between the mounted winxp share and the win98 share on box0
>>> is that the winxp mount point exhibits an inode link count of 1 after
>>> being mounted while the win98 mount point has an inode link count of 0:
>>>
>>> root:/mnt/share# ls -l
>>> total 8
>>> (...)
>>> drwxr-xr-x 0 root root 0 Feb 23 01:39 win98
>>> drwxr-xr-x 1 root root 0 Mar 13 13:32 winxp
>>>
>>> I have tried pretty much every mount option and the behavior is always
>>> the same.
>>>
>>> My questions are:
>>> 1. Why do Windows 98 mounted shares show this behavior?
>>> 2. Is there any way to correct this so as to be able to browse these
>>> shares indirectly (as described) from a Windows PC?
>>>
>>> Any information would be highly appreciated!
>>>
>>> Kind regards,
>>>
>>
>> That sounds like whatever tool you are using to "browse" is broken.
>> Just because the link count is 0 doesn't mean that it's a plain file.
>>
>> The inode link count is provided by the server via the NumberOfLinks
>> field in the QueryPathInfo response. What you are seeing here is just an
>> implementation difference between Linux and Windows. Linux usually has
>> a non-zero inode link count on directories, but at least some versions
>> of windows will report a link count of 0 for a directory.
>>
>> As best I can tell -- neither one is more correct than the other.
>> They're just differences in how this is implemented.
>>
>> Most likely, this will change in very recent kernels with Pavel's fix
>> to have the client fake up i_nlink values for directories, once Steve
>> gets around to merging it.
>>
>> --
>> Jeff Layton<jlayton-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
>> --
>> To unsubscribe from this list: send the line "unsubscribe linux-cifs" in
>> the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
>> More majordomo info at http://vger.kernel.org/majordomo-info.html
>
> It is already in mainline:
>
> http://git.samba.org/?p=sfrench/cifs-2.6.git;a=commit;h=71fece9511717750d86691e0f517ad04f3c8a801
>
Excellent! Thanks so much for the info!
--
Federico Sauter / Firmware developer
Innominate Security Technologies AG / protecting industrial networks
tel: +49.30.921028-210 / fax: +49.30.921028-020
Rudower Chaussee 13 / D-12489 Berlin / http://www.innominate.com/
Register Court: AG Charlottenburg, HR B 81603
Management Board: Dirk Seewald
Chairman of the Supervisory Board: Christoph Leifer
prev parent reply other threads:[~2012-03-22 9:28 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-03-21 11:18 Inode link count on mounted Win98 shares Federico Sauter
[not found] ` <4F69B8F9.9020808-LVkJPw3T+odGBRGhe+f61g@public.gmane.org>
2012-03-21 17:23 ` Jeff Layton
[not found] ` <20120321132300.42a95d51-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2012-03-21 18:24 ` Pavel Shilovsky
[not found] ` <CAKywueR4v0MVpL-LoNsyjcDgzV3Tp9hkOvK3gLOP9o-SkJX_bQ-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2012-03-22 9:28 ` Federico Sauter [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4F6AF0B2.1070403@innominate.com \
--to=fsauter-lvkjpw3t+odgbrghe+f61g@public.gmane.org \
--cc=jlayton-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org \
--cc=linux-cifs-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
--cc=piastryyy-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.